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1 General 


1.1. Introduction 


The CompactFlash Association (CFA) was established in October 1995 with the premise that 
CompactFlash (CF) technology would enable the introduction of a new class of advanced, small 
lightweight, low power mobile products that would significantly increase the productivity and 
enhance the lifestyles of millions of people. 


The concept behind CF technology was simple: to capture, retain and transport data, audio and 
images on CompactFlash Storage Cards. CF Storage Cards provided the capability to easily 
transfer all types of digital information and software between a large variety of digital systems. 
The CFA approved and published the CompactFlash standard. This vendor-independent 
specification enabled users to develop CF products that function correctly and are compatible 
with future CF designs, eliminating compatibility issues. 


Now the CFA has developed the CF+ specification to expand the CF concept beyond flash data 
storage and include I/O devices and magnetic disk data storage. The CF+ specification also 
includes the original Type | (3.3 mm thick) card and newer Type Il (5 mm thick) cards. While 
CompactFlash and many I/O devices can fit into the Type | card, the Type Il cards enable higher 
capacity CompactFlash cards, magnetic disk cards and many additional I/O cards. 


1.2 CFA Goals and Objectives 


The goals of the CFA are to promote and encourage the worldwide adoption of CF+ and 
CompactFlash (CF) technology as an open standard. The association’s primary objectives are to 
drive second-source availability; to promote acceptance of the CF+ specification as an industry 
standard across platforms and markets internationally; to ensure compatibility for users of CF and 
CF+ products, and to evolve the approved CF+ standard over time while ensuring backward 
compatibility. 


1.3. Overview of CompactFlash Storage Card 


CF+ is a small form factor card standard that encompasses CompactFlash (CF) flash data 
storage cards, magnetic disk cards and I/O cards including, but not limited to serial cards, 
Ethernet cards, fax/modem cards and wireless pager cards. 


The CF+ card provides high capacity data storage and I/O functions that electrically comply with 
the Personal Computer Memory Card International Association standard. (In Japan, the 
applicable standards group is JEITA.) Minor differences between the CF+ Specification and the 
PC Card ATA standard are documented in the Appendix at the end of this specification. Although 
the size of a matchbook, CF+ and CompactFlash Cards can be used with passive adapters in a 
PC-Card Type II or Type III socket. 


A CompactFlash Storage Card also runs in True IDE Mode that is electrically compatible with an 
IDE disk drive. Other CF+ devices such as magnetic disk drives may also run in True IDE Mode. 


The CompactFlash Storage Cards on-card intelligent controller manages interface protocols, data 
storage and retrieval as well as Error Correcting Code (ECC), defect handling and diagnostics, 
power management and clock control. Once the CompactFlash Storage Card has been 
configured by the host, it appears to the host as a standard ATA (IDE) disk drive. 


Similar controller functions are used with other CF+ cards allowing a wide variety of devices to be 
compatible with the CF+ specification 
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1.4 Related Documentation 
= PCMCIA PC Card Standard, 1995 


= PCMCIA PC Card ATA Specification, 1995 
= PCMCIA Metaformat Specification, 1997 
= PCMCIA Physical Specification Revision 7.0, 1999 


These documents can be obtained from: PCMCIA 
2635 North First St., Ste. 209 
San Jose, CA 95131 USA 
Phone: 408-433-2273 
Fax: 408-433-9558 


= AT Attachment Interface Document, American National Standards Institute, X3.221-1994 
=» ANSI NCITS 317-1998 AT Attachment - 4 with Packet Interface 


= ANSI INCITS 361-2002 AT Attachment - 6 Annex C Signal Integrity and UDMA 
Implementation Guide 


Copies of the ATA standards can be purchased from: 


ANSI or Global Engineering Documents 
11 West 42" Street Inverness Way East 

New York, NY 10036 USA Englewood, CO 80112-5704 
Tel: 212 642-4900 Tel: 800 854-7179 


Outside USA and Canada 303 792-2181 
International Sales Fax: 303 397-2740. 


Additional references can be found in the Bibliography at the end of this specification. 


1.5 Compatibility Requirements 


CompactFlash and CF+ are trademarks of the CompactFlash Association. All products that 
conform to this specification may use the CompactFlash and CF+ names with the appropriate 
license from the CompactFlash Association. 


The goal of this specification is to conform to the PC Card Specification when operating in the 
PCMCIA mode and to conform to the ATA-4 specification when operating in the True IDE Mode. 
If there is a conflict between this specification and the PC Card or the ATA-4 Specifications, the 
CompactFlash Specification shall apply. 


To conform to this specification, a CompactFlash Storage Card or CF+ Card shall conform to all 
physical, electrical and Metaformat specifications in this document. A CompactFlash Storage 
Card shall implement all PC Card and True IDE ATA commands listed in this specification. 
Commands can be implemented as “no operation” to meet this requirement. 
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2 Scope 


Elements of this Specification 


This specification is divided into five sections: Card Physical, Electrical Interface, Metaformat, 
Software Interface and CompactFlash Adapter. A brief overview of each section follows. 


Card Physical 


This section defines the dimensions and mechanical tolerances for CompactFlash Storage Cards 
and CF+ Cards. Specific pin lengths are defined to ensure that power is applied first and removed 
last during card insertion and removal. Reliability factors, such as connector mate/unmate cycles, 
environmental operating conditions and test methods are also specified. 


Electrical Interface 


This section provides detailed pinout and signal definitions for Memory Mode, I/O Mode and True 
IDE Mode CF Storage and CF+ Cards. Detailed functional and timing information is provided 
including the provision for reading 16 bit data on the low order 8 data bits (useful in 8 bit host 
systems) and the interpretation of status information returned by the CF Storage Card or CF+ 
Card. 


Metaformat 


This section describes the Card Information Structure (CIS), or Metaformat, on CompactFlash 
Storage Cards and CF+ Cards and how to interpret the Metaformat for the purpose of configuring 
and utilizing the card. 


Software Interface 


This section describes the software interface between the host and the CompactFlash Storage 
Card. This section does not apply to all CF+ Cards. 


CompactFlash Adapters 


This section describes the passive Type II PCMCIA adapters that can be used with the Type | or 
Type Il CompactFlash Storage Card or CF+ Card. 
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3 Card Physical 


3.1 General Description 


3.1.1 CompactFlash Storage Card 


The CompactFlash Storage Card contains a single chip controller and flash memory module(s) in 
a matchbook-sized package with a 50-pin connector consisting of two rows of 25 female contacts 
each on 50 mil (1.27 mm) centers. The controller interfaces with a host system allowing data to 
be written to and read from the flash memory module(s). 


Data 
In/Out Flash 
Host 
pret Controller ae Module(s) 
nterrace 


CompactFlash Storage Card 


Figure 1: CompactFlash Storage Card Block Diagram 


3.1.2 CF+ Card 


The CF+ card contains functions other than ATA flash memory, such as I/O (serial port, modem, 
LAN, etc) or non-flash storage (hard disk drive). Physical specifications are identical to 
CompactFlash cards (either Type | or Type II). 
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Data 
In/Out 
Host 
Controller 
Interface Control 


CF+ I/O Card 


Figure 2: CF+ Card Block Diagram 


3.2 CompactFlash Storage Card and CF+ Card Physical Specifications 


3.2.1 CF+ & CompactFlash Type | and Type Il Cards 


Refer to Table 1, Table 2: Type Il CompactFlash Storage Card and CF+ Card Physical 
Specifications, Figure 3 and Figure 4 for the CompactFlash Storage Card and the CF+ Card 
dimensions and physical specifications. 


Table 1: Type | CompactFlash Storage Card and CF+ Card Physical Specifications 


Length: | 36.4 + 0.15 mm (1.433 +.006 in.) 
Pawns | 42.80 0.40 rm (1.685 2.0061) 


Thickness 3.3 mm + 0.10 mm (.130 + .004 in.) 
Including Label Area: 


Table 2: Type Il CompactFlash Storage Card and CF+ Card Physical Specifications 


Length: | 36.4 +0.15 mm (1.433 +.006 in.) 
ee ee 


Thickness 5.0 mm maximum (.1968 in. maximum) 
Including Label Area: 
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(.063 in. + .002) 


1.60mm + .05 
y -99mm + .05 


3.30mm + .10 


j___]_saseieeiieseisisesezezzz Te (.039 in. + .002) 
(.130 in. + .004) A | 1 25 A 
1.01mm + .07 1.01mm + .07 
= (.040 in. + .003) (.040 in. + .003) 


2.44mm + .07 
(.096 in. + .003) 


7 S Optional 
ols Configuration 
HI a (See note.) 
El< 
= 9 | 10 2.15mm + .07 

wae 

2s 3 |2 o | (.085 in. + .003) 

Ho © 

ew |i SIS <O ols 

Es Hla 

Sa 4 

oN Ele 

os = o 2X 3.00mm + .07 

xa <I (2X .118 in. + .003) 

coy 
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1.65mm 
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|< | < 41.66mm + .13 (1.640 in. + .005) ? | 2 : A 
0.63mm + .07 
42.80mm + .10 (.025 in. + .003) 


4X R 0.5mm + .1 - 
(4X R .020 in. + .004) (1.685 in. +.004) 


Note: The optional notched configuration was shown in the CF Specification Rev. 1.0. In 
specification Rev. 1.2, the notch was removed for ease of tooling. This optional configuration 
can be used but it is not recommended. 


Figure 3: Type | CompactFlash Storage Card and CF+ Card Dimensions 
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1.01mm + .007 1.01mm + .07 
040 in. + .003) (.040 in. + .0@ 
Bottom 


99mm +.05 
(.039 in. + .002) 


8.5mm max. 
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=m 

S ie 

2 [2 See Note 1 
+H $ elt 
gE < Els 
& ” lio pe 
Ss 6S Nie 0] & 
ohe L19|O "Ic 
aneo Ne re thers 
x 19 ARS el * 
Nev as ey .s Section C-C 

5|8 S38 (Finger Grip) 
| © 5| 


—| 


| | 0.6mm + .076 
0.5mm + .076 


| 5mm ~- Cc 42.80mm + .101 
mee (1.685 in. +.004) 
0.6mm + .076 
Note 1: Area between dotted line and connector face 
4X R0.5mm + .1 may have reduced height. Height in this region is 
(4X .020 in. + .004) 5.0mm maximum and 3.2mm minimum. 
Detail A 


1.65mm 


Detail B 


Optional 
Centered Finger Grip 


(2 X) 6.16m 


10.00mm | 1mm 
min. min. 


Note: the recessed centered finger grip (Section C-C) is optional although it is recommended for CF+ Type 
Il cards. Additionally, it is recommended that Type II host slots include an ejector mechanism. 


Figure 4: Type Il CompactFlash Storage Card and CF+ Card Dimensions 
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3.2.2 Recommendations for Longer Type | and Type II Cards 


Both Type | and Type II CompactFlash Storage Cards and CF+ Cards may be lengthened 
beyond the 36.4 mm dimension. It is often desirable to include a bump up above the 3.3 mm or 5 
mm thickness as well. If the thickness is to be increased, it shall not be increased until after 39.5 
mm from the 50-pin connector and then increase at a 120° angle. Refer to Figure 5 and Figure 6 
for dimensions. 
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Figure 5: Longer Type | CompactFlash Storage Card and CF+ Card Dimensions 
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Figure 6: Longer Type II CompactFlash Storage Card and CF+ Card Dimensions 


3.2.3 CF+ Type | Extended 


Type | Extended is an optional physical format that allows for a thicker card along almost the 
entire length of a CF Type | card. A CF+ Type | Extended card has the same width and rails as a 
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Type | card; however, it can be extended in thickness (on the bottom) and in length. Refer to 
Figure 7 for allowable dimensions and recommendations. 
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Figure 7: CF+ Extended Card Dimensions 
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3.3 Connector Interface Specifications 


The specified CF Card connector interface shall be a 50-position, 2-piece pin-and-socket. The 
socket contacts shall be within the CF Card connector. The outermost plating of the pin and 
socket contact areas shall be a noble metal that is compatible with gold, and shall meet the 
performance requirements specified in Table 3: Connector Interface Requirement. 


Within this specification, the geometric plane established by the face of a fully engaged socket on 
its host connector is defined as “Datum A.” To evaluate interchangeability among various 
connectors, dimensional layouts should be referenced from Datum A, i.e., the CF Card Socket 
face or the CF Card Slot Header floor. 


Table 3: Connector Interface Requirement 


Category Item Standard Test Method 
Physical Housing Material High Temperature Plastic 
Housing Flammability Rating Certification 
Electrical Contact Resistance (w/ bulk) EIA-364-23A 
Performance 
Current Rating 
Insulation Resistance 1000 Megohms minimum, initial 100 Megohms 
E minimum, after 1 minute@500Vde | 
Dielectric Withstanding No shorting during 1 minute @ 500 Vac rms, EIA-364-20A 
Voltage with 1 mA maximum current leakage 
Mechanical Single Socket Holding Force | 4.9 N minimum push out @ 25 mm/minute EIA-364-29A 
Performance Single Pin Holding Force 


Total Mating Force 


Performance 


Total Inverse Mating Force 43.2 N minimum PCMCIA-Rev 
7.0-Card 
Physical 
Section 
ee ee eee 9.3.14 
Total Unmating Force 4.9 N minimum and 24.5 N maximum at 25 EIA-364-13A 
a MUMS eee ea es ee es Sl 
Durability 10,000 mating cycles, without exceeding low- EIA-364-09B 
level contact resistance 
Environmental Mechanical Shock No discontinuities greater than 100 ns, Test EIA-364-27A 


Vibration 
| Condition III 
Humidity 

Thermal Shock 
Mixed Flowing Gas 


EIA-364-32B 


Environmental Class II for 96 hours with EIA-364-65 


connector unmated 


3.3.1 CKF/CF+ Card Connector 


The socket-connector shall be located in the CF/CF+ Card as shown in Figure 3 and Figure 4. 
The CF/CF+ Card socket-connector interface layout shall match the host pin-connector layout as 
shown in Figure 8. The pin entry ports on the CF/CF+ Card socket-connector shall be configured 
as shown in Figure 9. The location of “first wipe on pin engagement” within the CF/CF+ Card 
socket-connector is shown in Figure 10. 
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The mechanical outlines for CF/CF+ Card Sockets are Figure 11: Straddle Mount CF/CF+ Card 
Socket and Figure 12: Surface Mount CF/CF+ Card Socket. 


3.3.2 Host Connector 


12 


The host (CF/CF+ Card slot) pin-connector shall be a 50-pin connector with opening, polarization, 
and pin location as shown in Figure 13. The pin size and shape shall be as shown in Figure 14. 
The type and length for each pin number is shown in Figure 10. 


If the host is a Type II PCMCIA PC Card, the pin-connector shall also conform to the physical 
specifications in Section 7.2 CompactFlash Adapter Specifications. 


In all cases, the CF/CF+ Card shall be guided by the host connector for a minimum of 6.5 mm 
before the socket connector fully seats on the host connector. To ensure alignment of the 
CF/CF+ Card to the host connector, the CF/CF+ Card shall be guided for a minimum distance of 
19.0 mm before engagement. 


The mechanical outlines for CF/CF+ Card slot connectors are Figure 15: Straddle Mount CF/CF+ 
Card Adapter Header, Figure 16: Surface Mount Right Angle CF/CF+ Type | Card Slot Header 
and Figure 17: Surface Mount Right Angle CF/CF+ Type Il Card Slot Header. Recommended 
Pad or Hole PCB Patterns for various tail configurations and mounting methods are shown in 
Figure 18 to Figure 22. 


1.27mm 
(.050 in.) Pe > 24 Equal Spaces x 1.27mm =| 30.48mm 


=a | (1.2 in.) 
7 ey 0 : 
> 1.27mm L —A— 
& 


(.050 in.) 50 x 0 0.44 + 0.02 
2 0.05|A ©| Be 


Figure 8: Position 2 Row Pin Pattern 
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0.94mm (.037 in.) Min. 


Figure 9: Socket Connector Entry 


Power 1,13, 38&50 | 5.00[.197] | 0.50[.020] | 4.50[.177] | 0.50[.020] | 0.50-2.50 
[.020 - .098] 


General Allother pins | 4.25[.167] | 0.50[.020] | 3.75[.148] | 0.50[.020] | 0.50 - 2.50 
[.020 - .098] 
Detect 25, 26 3.50 [.138] | 0.50[.020] | 3.00[.118] | 0.50[.020] | 0.50-2.50 
[.020 - .098] 
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Pin Socket 


Notes: 

LU Pin/Socket contact area. 

2| L4 is the point of first engagement for mating with the socket 
contacts/housing mounted within the card. 


Figure 10: Pin and Socket Detail 
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Figure 11: Straddle Mount CF/CF+ Card Socket 
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Figure 12: Surface Mount CF/CF+ Card Socket 
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Figure 13: 50-Pin Connector Opening 
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Figure 14: Header Pin Detail 
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Figure 15: Straddle Mount CF/CF+ Card Adapter Header 
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Pin Type | Interface Dim A Pin No. 
2X @ 2.20mm detect 3.50mm (.138 in.) 25, 26 
(.087 in.) 
general | 4.25mm (.167 in.)| all other pins 
~~ 0.635mm Typ power | 5.00mm (.197 in.)| 1, 13, 38, 50 
(0250in.) gp 
q | J ] A] 
iF UTE ga 
qa 
q ] 
= 
43.03mm + 0.06 
—— — 
(1.694 in.) 
1.75mm 
oe 30.48mm Ref (.069 in.) 
: ; (1.200 in.) 
i Pin 2. 
| Pipin26 Pin 50 
Oe 0 oq 
= +4 
HODDIOUIOO0O0000000CU00DCCOODDECOOODADAOODADNoOOD 
4a. \0 —A 
1.27mm Typ iF 
(.050 in.) 79mm + 0.05 A | 
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>| 2X .89mm + 0.05 
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ln 
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| 


The Direction of Inserting Card 


Recommended PCB Solder Pad Pattern 
Note: The location of mounting holes, alignment pegs and solder hold-downs may vary. 


Figure 16: Surface Mount Right Angle CF/CF+ Type | Card Slot Header 
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Pin Type | Interface Dim A Pin No. 
2X 0 2.20mm detect | 3.50mm (.138 in.) 25, 26 
(.087 in.) general | 4.25mm (.167 in.) | all other pins 
ple 0.635mm Typ power | 5.00mm (.197 in.) | 1, 13, 38, 50 
(0250in.) gy 
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lO a u 
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; : (1.200 in.) +75tam | -132in.) 


i Pin 25 (.069 in.) 
Pin 26 Pin 50: 
cy yp tt 


; 


a 
=n ve x 4 
# = 
(oso) oe | .79mm + 0.05 A y Q 
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— >| — 2X .89mm + 0.05 i 
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5.60mm + 0.08 
(220in.) — +> 
31.11mm Section A-A 
i (1.225 in.) 


Ot 
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The Direction of Inserting Card 


Recommended PCB Solder Pad Pattern 
Note: The location of mounting holes, alignment pegs and solder hold-downs may vary. 


Figure 17: Surface Mount Right Angle CF/CF+ Type Il Card Slot Header 
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Figure 18: Two Row SMT Host PCB Pattern 


31.11mm 
$$ : 
(1.225 in.) > 
0.40mm Typ 


0.635mm Typ fas 
(.0250 in.) (.016 in.) 


' 
TTT EES 
f 


26 4 25 
1 Insert Card 5 


Figure 19: Single Row SMT Host PCB Pattern 
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Figure 20: Right Angle Through Hole Host PCB Pattern 
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Figure 21: Vertical Through Hole Host PCB Pattern 
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Figure 22: Alternate Right Angle Through Hole Host PCB Pattern 
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ELECTRICAL INTERFACE 


4 Electrical Interface 


Physical Description 


The host is connected to the CompactFlash Storage Card or CF+ Card using a standard 50-pin 
connector. The connector in the host consists of two rows of 25 male contacts each on 50 mil 
(1.27 mm) centers. 


Pin Assignments and Pin Type 


The signal/pin assignments are listed in Table 4. Low active signals have a “-” prefix. Pin types 
are Input, Output or Input/Output. Section 4.3 defines the DC characteristics for all input and 
output type structures. 


Electrical Description 


The CompactFlash Storage Card functions in three basic modes: 1) PC Card ATA using I/O 
Mode, 2) PC Card ATA using Memory Mode and 3) True IDE Mode, which is compatible with 
most disk drives. CompactFlash Storage Cards are required to support all three modes. The CF+ 
Cards normally function in the first and second modes, however they can optionally function in 
True IDE mode. The configuration of the CompactFlash Card shall be controlled using the 
standard PCMCIA configuration registers starting at address 200h in the Attribute Memory space 
of the storage card or for True IDE Mode, pin 9 being grounded. The configuration of the CF+ 
Card shall be controlled using configuration registers starting at the address defined in the 
Configuration Tuple (CISTPL_CONFIG) in the Attribute Memory space of the CF+ Card. 


Table 5 describes the I/O signals. Signals whose source is the host are designated as inputs 
while signals that the CompactFlash Storage Card or CF+ Card sources are outputs. The 
CompactFlash Storage Card and CF+ Card logic levels conform to those specified in the 
PCMCIA Release 2.1 specification. In Table 5, each signal has three possible operating modes: 
1)PC Card Memory, 2) PC Card I/O and 3) True IDE. True IDE mode is required for 
CompactFlash Storage cards, and optional for CF+ Cards. All outputs from the card are 
totempole except the data bus signals that are bi-directional tri-state. Refer to Section 4.3 for 
definitions of Input and Output type. 
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Table 4: Pin Assignments and Pin Type 


PC Card peneey Mode PC Card I/O Mode True IDE Mode* 


al ce ne ee Ea aes om wee rar Pages) a a 
| Ground | | Ground | | Ground _| 

Ea | a 
Ee aC a 
mea a ea 
eee ae Noe ee see see Pee | 
Ese Sree State Sra aes ae ae 
i Te 
aas| woe: [rl mz | a0] aoe | a |i tz toe | Ae ir az | 
PE A ED 
ID 
113 | vec | | Power | 13 | vec | | Power | 13 | vec | | Power | 
se eet lace Ii ee) 
HA Noa 
116 | aoa | 1 {| uz |te {| aoe fot | nz te | ao for fo onz | 
Pera ca i ST 
Pr OT 
We Ma Tel 
ET a aA 
| 21 | poo | vo [t1z,0z3] 21 | poo | vo [1z,oz3] 21 | boo | vo | 112,023 | 
eee alee areas Sl or [eer | a eet soc co | 
Pe see ee ee eee 
es cede leo cme |e eco one 
ee a TO me 


Pea [vst [0 | Ground [ce [ver | 0 eran [ae | ver [0 | Ground 


13Z 
HSTROBE® 
-HDMARDY? 
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Num Name |Type| Type Num Name Type Type Num Name Type Type 
-IOWR -IOWR 
epee ee | 


| -we? | 
Fe rc oc 
Fae | vec | | Power | ae | voc | | Power | aa | voc | | Power 
Pao [ose | 1 | mz [so | coe | 1 | wz | 20 | coe | 1 | mu 
ee ee 


| RESET | | RESET | | -RESET | 


-WAIT -WAIT ONt 
pened 
ee 
po | oz | 


| 43 | -INPACK | Oo | | INPACK | | DMARQ_| O21 
fees eft ee oe eee ee 
ras | avor [of ort | as [sae [0 | ort | as | pase [10 [iu ont 
ras [ever [0 | ort | as [-srscne | o | ort | a6 [pons [10 [iu.onr| 
Peo [eno | [eure | so [eno | | crauna | so [en || coun | 


Note: 1) These signals are required only for 16 bit accesses and not required when installed in 8 bit 
systems. Devices should allow for 3-state signals not to consume current. 


2) The signal should be grounded by the host. 
3) The signal should be tied to VCC by the host. 
4) The mode is optional for CF+ Cards, but required for CompactFlash Storage Cards. 


5) The -CSEL signal is ignored by the card in PC Card modes. However, because it is not pulled up 
on the card in these modes, it should not be left floating by the host in PC Card modes. In these 
modes, the pin should be connected by the host to PC Card A25 or grounded by the host. 


6) If DMA operations are not used, the signal should be held high or tied to VCC by the host. For 
proper operation in older hosts: while DMA operations are not active, the card shall ignore this signal, 
including a floating condition 


7) Signal usage in True IDE Mode except when Ultra DMA mode protocol is active. 
8) Signal usage in True IDE Mode when Ultra DMA mode protocol DMA Write is active. 
9) Signal usage in True IDE Mode when Ultra DMA mode protocol DMA Read is active. 
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Table 5: Signal Description 


A10 - AO 8,10,11,12, | These address lines along with the -REG signal are used to 
(PC Card Memory Mode) 14,15,16,17, | select the following: The I/O port address registers within the 


A10 - AO 
(PC Card I/O Mode) 


A2 - AO 
(True IDE Mode) 


BVD1 
(PC Card Memory Mode) 


-STSCHG 
(PC Card I/O Mode) 
Status Changed 


-PDIAG 
(True IDE Mode) 


BVD2 
(PC Card Memory Mode) 


-SPKR 
(PC Card I/O Mode) 


-DASP 
(True IDE Mode) 


-CD1, -CD2 
(PC Card Memory Mode) 


-CD1, -CD2 
(PC Card I/O Mode) 


-CD1, -CD2 
(True IDE Mode) 


-CE1, -CE2 
(PC Card Memory Mode) 
Card Enable 


-CE1, -CE2 
(PC Card I/O Mode) 
Card Enable 


-CSO, -CS1 
(True IDE Mode) 
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18,19,20 


18,19,20 


CompactFlash Storage Card or CF+ Card, the memory mapped 
port address registers within the CompactFlash Storage Card or 
CF+ Card, a byte in the card's information structure and its 
configuration control and status registers. 


This signal is the same as the PC Card Memory Mode signal. 


In True IDE Mode, only A[2:0] are used to select the one of eight 
registers in the Task File, the remaining address lines should be 
grounded by the host. 


This signal is asserted high, as BVD1 is not supported. 


This signal is asserted low to alert the host to changes in the 
READY and Write Protect states, while the I/O interface is 
configured. Its use is controlled by the Card Config and Status 
Register. 


In the True IDE Mode, this input / output is the Pass Diagnostic 
signal in the Master / Slave handshake protocol. 


This signal is asserted high, as BVD2 is not supported. 


This line is the Binary Audio output from the card. If the Card 
does not support the Binary Audio function, this line should be 
held negated. 


In the True IDE Mode, this input/output is the Disk Active/Slave 
Present signal in the Master/Slave handshake protocol. 


These Card Detect pins are connected to ground on the 
CompactFlash Storage Card or CF+ Card. They are used by the 
host to determine that the CompactFlash Storage Card or CF+ 
Card is fully inserted into its socket. 


This signal is the same for all modes. 


This signal is the same for all modes. 


These input signals are used both to select the card and to 
indicate to the card whether a byte or a word operation is being 
performed. -CE2 always accesses the odd byte of the word. 
-CE1 accesses the even byte or the Odd byte of the word 
depending on AO and -CE2. A multiplexing scheme based on AO, 
-CE1, -CE2 allows 8 bit hosts to access all data on DO-D7. See 
Table 27, Table 29, Table 31, Table 35, Table 36 and Table 37. 


This signal is the same as the PC Card Memory Mode signal. 


In the True IDE Mode, -CSO is the chip select for the task file 
registers while -CS1 is used to select the Alternate Status 
Register and the Device Control Register. 

While -DMACK is asserted, -CSO and —CS1 shall be held 
negated and the width of the transfers shall be 16 bits. 
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-CSEL 
(PC Card Memory Mode) 


-CSEL 
(PC Card I/O Mode) 


-CSEL 
(True IDE Mode) 


D15 - DOO 
(PC Card Memory Mode) 


D15 - DOO 
(PC Card I/O Mode) 


D15 - DOO 
(True IDE Mode) 


GND 
(PC Card Memory Mode) 


GND 
(PC Card I/O Mode) 


GND 
(True IDE Mode) 


-INPACK 
(PC Card Memory Mode) 


-INPACK 
(PC Card I/O Mode) 
Input Acknowledge 


DMARQ 
(True IDE Mode) 


-IORD 
(PC Card Memory Mode) 
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31,30,29,28, 
27,49,48,47, 


6,5,4,3,2, 
23, 22, 21 


This signal is not used for this mode, but should be connected by 
the host to PC Card A25 or grounded by the host. 


This signal is not used for this mode, but should be connected by 
the host to PC Card A25 or grounded by the host. 


This internally pulled up signal is used to configure this device as 
a Master or a Slave when configured in the True IDE Mode. 
When this pin is grounded, this device is configured as a Master. 
When the pin is open, this device is configured as a Slave. 


These lines carry the Data, Commands and Status information 
between the host and the controller. DOO is the LSB of the Even 
Byte of the Word. D08 is the LSB of the Odd Byte of the Word. 


This signal is the same as the PC Card Memory Mode signal. 


In True IDE Mode, all Task File operations occur in byte mode 
on the low order bus D[7:0] while all data transfers are 16 bit 
using D[15:0]. 


Ground. 

This signal is the same for all modes. 
This signal is the same for all modes. 
This signal is not used in this mode. 


The Input Acknowledge signal is asserted by the CompactFlash 
Storage Card or CF+ Card when the card is selected and 
responding to an I/O read cycle at the address that is on the 
address bus. This signal is used by the host to control the enable 
of any input data buffers between the CompactFlash Storage 
Card or CF+ Card and the CPU. 


This signal is a DMA Request that is used for DMA data 
transfers between host and device. It shall be asserted by the 
device when it is ready to transfer data to or from the host. For 
Multiword DMA transfers, the direction of data transfer is 
controlled by -IORD and -IOWR. This signal is used in a 
handshake manner with -DMACK, i.e., the device shall wait until 
the host asserts -DMACK before negating DMARQ, and re- 
asserting DMARQ if there is more data to transfer. 


DMARQ shall not be driven when the device is not selected. 


While a DMA operation is in progress, -CSO and —CS1 shall be 
held negated and the width of the transfers shall be 16 bits. 


If there is no hardware support for DMA mode in the host, this 
output signal is not used and should not be connected at the 
host. In this case, the BIOS must report that DMA mode is not 
supported by the host so that device drivers will not attempt DMA 
mode. 


A host that does not support DMA mode and implements both 
PCMCIA and True-IDE modes of operation need not alter the 
PCMCIA mode connections while in True-IDE mode as long as 
this does not prevent proper operation in any mode. 


This signal is not used in this mode. 
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-IORD This is an I/O Read strobe generated by the host. This signal 

(PC Card I/O Mode) gates I/O data onto the bus from the CompactFlash Storage 
Card or CF+ Card when the card is configured to use the I/O 
interface. 

-IORD In True IDE Mode, while Ultra DMA mode is not active, this 

(True IDE Mode — Except signal has the same function as in PC Card I/O Mode. 

Ultra DMA Protocol 

Active) 

-HDMARDY In True IDE Mode when Ultra DMA mode DMA Read is active, 

(True IDE Mode — In Ultra this signal is asserted by the host to indicate that the host is read 

DMA Protocol DMA to receive Ultra DMA data-in bursts. The host may negate 

Read) -HDMARDY to pause an Ultra DMA transfer. 

HSTROBE In True IDE Mode when Ultra DMA mode DMA Write is active, 

(True IDE Mode — In Ultra this signal is the data out strobe generated by the host. Both the 

DMA Protocol DMA rising and falling edge of HSTROBE cause data to be latched by 

Write) the device. The host may stop generating HSTROBE edges to 
pause an Ultra DMA data-out burst. 


-IOWR This signal is not used in this mode. 
(PC Card Memory Mode) 


-IOWR The I/O Write strobe pulse is used to clock I/O data on the Card 

(PC Card I/O Mode) Data bus into the CompactFlash Storage Card or CF+ Card 
controller registers when the CompactFlash Storage Card or 
CF+ Card is configured to use the I/O interface. 


The clocking shall occur on the negative to positive edge of the 
signal (trailing edge). 


-IOWR In True IDE Mode, while Ultra DMA mode protocol is not active, 
(True IDE Mode — Except this signal has the same function as in PC Card I/O Mode. 

Ultra DMA Protocol When Ultra DMA mode protocol is supported, this signal must be 
Active) negated before entering Ultra DMA mode protocol. 

STOP In True IDE Mode, while Ultra DMA mode protocol is active, the 
(True IDE Mode — Ultra assertion of this signal causes the termination of the Ultra DMA 
DMA Protocol Active) burst. 

-OE I 9 This is an Output Enable strobe generated by the host interface. 
(PC Card Memory Mode) It is used to read data from the CompactFlash Storage Card or 


CF+ Card in Memory Mode and to read the CIS and 
configuration registers. 


-OE In PC Card I/O Mode, this signal is used to read the CIS and 
(PC Card I/O Mode) configuration registers. 

-ATA SEL To enable True IDE Mode this input should be grounded by the 
(True IDE Mode) host. 
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READY 
(PC Card Memory Mode) 


-IREQ 
(PC Card I/O Mode) 


INTRQ 
(True IDE Mode) 


-REG 
(PC Card Memory Mode) 
Attribute Memory Select 


-REG 
(PC Card I/O Mode) 


-DMACK 
(True IDE Mode) 


RESET 
(PC Card Memory Mode) 


RESET 
(PC Card I/O Mode) 


-RESET 
(True IDE Mode) 


VCC 
(PC Card Memory Mode) 
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In Memory Mode, this signal is set high when the CompactFlash 
Storage Card or CF+ Card is ready to accept a new data transfer 
operation and is held low when the card is busy. 


At power up and at Reset, the READY signal is held low (busy) 
until the CompactFlash Storage Card or CF+ Card has 
completed its power up or reset function. No access of any type 
should be made to the CompactFlash Storage Card or CF+ Card 
during this time. 


Note, however, that when a card is powered up and used with 
RESET continuously disconnected or asserted, the Reset 
function of the RESET pin is disabled. Consequently, the 
continuous assertion of RESET from the application of power 
shall not cause the READY signal to remain continuously in the 
busy state. 


I/O Operation — After the CompactFlash Storage Card or CF+ 
Card has been configured for I/O operation, this signal is used as 
-Interrupt Request. This line is strobed low to generate a pulse 
mode interrupt or held low for a level mode interrupt. 


In True IDE Mode signal is the active high Interrupt Request to 
the host. 


This signal is used during Memory Cycles to distinguish between 
Common Memory and Register (Attribute) Memory accesses. 
High for Common Memory, Low for Attribute Memory. 


The signal shall also be active (low) during I/O Cycles when the 
I/O address is on the Bus. 


This is a DMA Acknowledge signal that is asserted by the host in 
response to DMARQ to initiate DMA transfers. 


While DMA operations are not active, the card shall ignore the 
-DMACK signal, including a floating condition. 


If DMA operation is not supported by a True IDE Mode only host, 
this signal should be driven high or connected to VCC by the 
host. 


A host that does not support DMA mode and implements both 
PCMCIA and True-IDE modes of operation need not alter the 
PCMCIA mode connections while in True-IDE mode as long as 
this does not prevent proper operation all modes. 


The CompactFlash Storage Card or CF+ Card is Reset when the 
RESET pin is high with the following important exception: 


The host may leave the RESET pin open or keep it continually 
high from the application of power without causing a continuous 
Reset of the card. Under either of these conditions, the card 
shall emerge from power-up having completed an initial Reset. 


The CompactFlash Storage Card or CF+ Card is also Reset 
when the Soft Reset bit in the Card Configuration Option 
Register is set. 


This signal is the same as the PC Card Memory Mode signal. 


In the True IDE Mode, this input pin is the active low hardware 
reset from the host. 


+5 V, +3.3 V power. 
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Vcc 
(PC Card I/O Mode) 


Vcc 
(True IDE Mode) 


O 33 


This signal is the same for all modes. 


This signal is the same for all modes. 


-VS1 Voltage Sense Signals. -VS1 is grounded on the Card and 

-VS2 40 sensed by the Host so that the CompactFlash Storage Card or 

(PC Card Memory Mode) CF+ Card CIS can be read at 3.3 volts and -VS2 is reserved by 
PCMCIA for a secondary voltage and is not connected on the 
Card. 

-VS1 This signal is the same for all modes. 

-VS2 

(PC Card I/O Mode) 

-VS1 This signal is the same for all modes. 

-VS2 

(True IDE Mode) 

-WAIT O 42 The -WAIT signal is driven low by the CompactFlash Storage 

(PC Card Memory Mode) Card or CF+ Card to signal the host to delay completion of a 
memory or I/O cycle that is in progress. 

-WAIT This signal is the same as the PC Card Memory Mode signal. 

(PC Card I/O Mode) 

IORDY In True IDE Mode, except in Ultra DMA modes, this output 

(True IDE Mode — Except signal may be used as IORDY. 

Ultra DMA Mode) 

-DDMARDY In True IDE Mode, when Ultra DMA mode DMA Write is active, 

(True IDE Mode — Ultra this signal is asserted by the host to indicate that the device is 

DMA Write Mode) read to receive Ultra DMA data-in bursts. The device may 
negate -DDMARDY to pause an Ultra DMA transfer. 

DSTROBE In True IDE Mode, when Ultra DMA mode DMA Write is active, 

(True IDE Mode — Ultra this signal is the data out strobe generated by the device. Both 

DMA Read Mode) the rising and falling edge of DSTROBE cause data to be latched 
by the host. The device may stop generating DSTROBE edges 
to pause an Ultra DMA data-out burst. 

-WE I 36 This is a signal driven by the host and used for strobing memory 


(PC Card Memory Mode) 


-WE 
(PC Card I/O Mode) 


-WE 
(True IDE Mode) 


WP 
(PC Card Memory Mode) 
Write Protect 


-IO1S16 
(PC Card I/O Mode) 


-lIOCS16 
(True IDE Mode) 
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write data to the registers of the CompactFlash Storage Card or 
CF+ Card when the card is configured in the memory interface 
mode. It is also used for writing the configuration registers. 


In PC Card I/O Mode, this signal is used for writing the 
configuration registers. 


In True IDE Mode, this input signal is not used and should be 
connected to VCC by the host. 


Memory Mode — The CompactFlash Storage Card or CF+ Card 
does not have a write protect switch. This signal is held low after 
the completion of the reset initialization sequence. 


I/O Operation — When the CompactFlash Storage Card or CF+ 
Card is configured for I/O Operation Pin 24 is used for the -I/O 


Selected is 16 Bit Port (-lIOIS16) function. A Low signal indicates 
that a 16 bit or odd byte only operation can be performed at the 
addressed port. 


In True IDE Mode this output signal is asserted low when this 
device is expecting a word data transfer cycle. 
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4.3 Electrical Specification 
Table 6, Table 7, Table 8, Table 9, and Table 11 define all D.C. Characteristics for the 
CompactFlash Storage Card and CF+ Card Series. Unless otherwise stated, conditions are: 
Vec = 5V +10% 
Veco =3.3V 45% 
Ta = 0°C to 60°C 


Table 6: Absolute Maximum Conditions 


Input Power Vcc -0.3V min. to 6.5V max. 
Voltage on any pin except Vcc with respect to GND. -0.5V min. to Vcc + 0.5V max. 


Table 7: Input Power 


Voltage Maximum Average RMS Current Measurement Method 


3.3V + 5% 75 mA (500 mA in Power Level 1) 3.3V at 25°C 
5.0V + 10% 100 mA (500 mA in Power Level 1) 5.0V at 25°C 


CompactFlash and CF+ products shall operate correctly in both voltage ranges as shown in 
Table 7: Input Power above. To comply with this specification, current requirements shall not 
exceed the maximum limit. 


The maximum average RMS current for CompactFlash cards is 75 mA at 3.3V and 100 mA at 5V. 
For CF+ cards, two power levels are defined. Power Level 0 has the same current specifications 
as CompactFlash cards, while Power Level 1 has an increased maximum current of 500 mA for 
both 3.3V and 5V. 


Alert: The CompactFlash Association is considering allowing higher Input Power for 
CompactFlash cards in future revisions of the standard in order to support increased levels of 
performance. Host developers should ensure that their new designs use the existing 
mechanisms (e.g. disable Power Level 1, Set Features) as needed to restrict card power levels to 
those that are supported by the host platform. Existing host designs based on previous revisions 
of this standard would not be affected as the card performance is limited by the previously 
defined interface timing modes. 


CF+ cards shall operate within the specifications for Power Level 0 at power on and after reset. 
CF+ cards shall also support CIS reads and (for ATA CF+ cards only) ATA Identify Device 
commands in Power Level 0. This requirement allows the host device to determine whether the 
CF+ card has commands, which require Power Level 1 (see Sections 5.2 and 6.2.1.6.31). If the 
host cannot support Power Level 1, the host can either disable Power Level 1 commands in the 
CF+ card (see Sections 4.4.5 and 6.2.1.29 or reject the CF+ card. 


An example of a CF+ card using both Power Level 0 and Power Level 1 is a disk drive. Typically, 
commands that require the spindle to rotate (e.g., read/write commands) are Power Level 1 
commands. CF+ disk drives shall make provisions to accommodate the execution of CIS reads 
and ATA Identify Device commands in Power Level 0; that is, without rotating the spindle. 
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4.3.1 Current Measurement 


For Compact Flash Storage Cards, current measurement is accomplished by connecting an amp 
meter (set to the 2 amp scale range) with a fast current probe with an RC filter with a time 
constant of 0.1 msec, in series with the Vcc supply to the CompactFlash Storage Card. Current 
measurements are to be taken while looping on a data transfer command with a sector count of 
128. Current consumption values for both read and write commands are not to exceed the 
Maximum Average RMS Current specified in the above Table 7: Input Power. 


For CF+ cards, a fast (>1 MHz) current probe monitors current on the Vcc supply to the CF+ 
card. The output of the current probe is filtered by an RC filter with a time constant of 0.1 msec. 
The output of the filter is monitored with a fast (>1 MHz) scope or other monitor. The filtered 
output measured in this way shall not exceed the specifications shown for Power Level 0 (for all 
CF+ cards) and for Power Level 1 (for CF+ cards supporting Power Level 1). 


RC Filter 
Current WV > Scope or Other 
Probe Measurement 
j —— .01uF Device 

ee + DC - 1MHz Min 
a = elle Z,, = 10MQ Min 

CF+ 

Card 


Figure 23: CF+ Power Supply Current Measurement Method 


4.3.2 Input Leakage Current 
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Note: In Table 8 below, x refers to the characteristics described in Section 4.3.3. For example, I1U indicates 
a pull-up resistor with a type 1 input characteristic. 


Table 8: Input Leakage Current 


[pe [Parameter Symbor [Conditions | wiv [1¥ | wax [Unt 
hz | teptteatage covert |e [wn=vecrwi=onal 1 [| 1 | oa 


Tow | PuupRessor [peur | veo=s.ov [som [| s00r | om | 
0 | Putrdownresiior [ror | veo=s.ov | som | | soo | om | 


Note: The minimum pull-up resistor leakage current meets the PCMCIA specification of 10k ohms but is 
intentionally higher in the CompactFlash Specification to reduce power use. 
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4.3.3 Input Characteristics 


Table 9: Input Characteristics 


Input Voltage Vih Volts 
CMOS Vil 


Input Voltage Vih oe 
CMOS Vil 

Input Voltage Vth - 8 a 8 hae 
CMOS Vil 

Schmitt Trigger 1.0 2.0 


Notes: 1) Per PCMCIA Electrical Specification Signal Interface Table 4-18 note 1, the host provides a logic 
output high voltage for a CMOS load of .9 x VCC. For a 5 volt product, this translates to .9 x 4.5 = 
4.05 volts minimum Voh. 


4.3.4 Output Drive Type 


Note: In Table 10 below, x refers to the characteristics described in Section 4.3.5. For example, OT3 refers 
to Totempole output with a type 3 output drive characteristic. 


Table 10: Output Drive Type 


Output Type Valid Conditions 
OTx Totempole loh & lol 
OZx Tri-State N-P Channel loh & lol 


OPx P-Channel Only loh Only 
ONx N-Channel Only lol Only 
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4.3.5 Output Drive Characteristics 
Table 11: Output Drive Characteristics 


loh = -4 mA 


lol=4 mA 


loh = -4 mA 


lol=4 mA 


loh = -4 mA 


lol=4 mA 
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4.3.6 Signal Interface 


Electrical specifications shall be maintained to ensure data reliability. Additional requirements are 
necessary for Advanced Timing Modes and Ultra DMA modes operations. See sections 4.3.7 
and 4.3.8 for additional information. 


Table 12: Electrical Interface 


Item Signal Card "° Host "© 
Control Signal -CE1 Pull-up to Vec 500 KQ > R > 50 KO and 

-CE2 shall be sufficient to keep inputs 

inactive when the pins are not 

-REG connected at the host. ' 

-IORD 

-IOWR 

-OE Pull-up to Vec 500 KQ > R > 50 KQ. *"” 

-WE 


RESET Pull-up to Vec 500 KQ > R > 50 KQ. * 


Status Signal READY Pull-up to Vec R > 10 KQ. ® 
-WAIT 
WP 
-INPACK In PCMCIA modes Pull-up to 


Vcc R > 10 Ka. 4 


In True IDE mode, if DMA 
operation is supported by 
the host, Pull-down to 
Gnd R > 5.6 Ka. ° 


PCMCIA / True IDE hosts 
switch the pull-up to pull- 
down in True IDE mode if 
DMA operation is supported. 


The PCMCIA mode Pull-up 
may be left active during 
True IDE mode if True IDE 
DMA operation is not 


supported. 
Address A[10:0] 
-CSEL 
Data Bus D[15:0] h 
Card Detect -CD[2:1] Connected to GND in the card 
Voltage Sense -VS1 Pull-up to Vec 10 KO <R< 
VS2 100KQ. 
Battery/Detect BVD[2:1] Pull-up R = 50 KQ. ane 


Notes: 1) Control Signals: each card shall present a load to the socket no larger than 50 pF ° at a DC 
current of 700 pA low state and 150 A high state, including pull-resistor. The socket shall be able to 
drive at least the following load "© while meeting all AC timing requirements: (the number of sockets 
wired in parallel) multiplied by (50 pF with DC current 700 nA low state and 150 pA high state per 
socket). 


2) Resistor is optional. 
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4.3.7 Addi 


3) Status Signals: the socket shall present a load to the card no larger than 50 pF '° at a DC current 
of 400 yA low state and 100 pA high state, including pull-up resistor. The card shall be able to drive at 
least the following load "© while meeting all AC timing requirements: 50 pF at a DC current of 400 pA 
low state and 100 uA high state. 


4) Status Signals: the socket shall present a load to the card no larger than 50 pF '° at a DC current 
of 400 yA low state and 100 pA high state, including pull-up resistor. The card shall be able to drive at 
least the following load 1° while meeting all AC timing requirements: 50 pF at a DC current of 400 pA 
low state and 100 uA high state. 


5) Status Signals: the socket shall present a load to the card no larger than 50 pF '° at a DC current 
of 400 A low state and 100 pA high state, including pull-up resistor. The card shall be able to drive at 
least the following load "© while meeting all AC timing requirements: 50 pF at a DC current of 400 pA 
low state and 1100 nA high state. 


6) BVD2 was not defined in the JEIDA 3.0 release. Systems fully supporting JEIDA release 3 SRAM 
cards shall pull-up pin 45 (BVD2) to avoid sensing their batteries as “Low.” 


7) Address Signals: each card shall present a load of no more than 100pF '° at a DC current of 
450A low state and 150A high state. The host shall be able to drive at least the following load ie 
while meeting all AC timing requirements: (the number of sockets wired in parallel) multiplied by 
(100pF with DC current 450A low state and 150A high state per socket). 


8) Data Signals: the host and each card shall present a load no larger than 50pF 1° at a DC current of 
450uA and 150A high state. The host and each card shall be able to drive at least the following load 
1° while meeting all AC timing requirements: 100pF with DC current 1.6mA low state and 300A high 
state. This permits the host to wire two sockets in parallel without derating the card access speeds. 


9) Reset Signal: This signal is pulled up to prevent the input from floating when a CFA to PCMCIA 
adapter is used in a PCMCIA revision 1 host. However, to minimize DC current drain through the 
pull-up resistor in normal operation the pull-up should be turned off once the Reset signal has been 
actively driven low by the host. Consequently, the input is specified as an I2Z because the resistor is 
not necessarily detectable in the input current leakage test. 


10) Host and card restrictions for CF Advanced Timing Modes and Ultra DMA modes: See section 
4.3.7: Additional Requirements for CF Advanced Timing Modes and section 4.3.8: Ultra DMA 
Electrical Requirements for additional required limitations on the implementation of CF Advanced 
Timing modes and Ultra DMA modes respectively. 


tional Requirements for CF Advanced Timing Modes 


The CF Advanced Timing modes include PCMCIA I/O and Memory modes that are 100ns or faster and True 
IDE PIO Modes 5,6 and Multiword DMA Modes 3,4. 


When operating in CF Advanced timing modes, the host shall conform to the following requirements: 


1) 


2) 


Only one CF device shall be attached to the CF Bus. 


The host shall not present a load of more than 40pF to the device for all signals, including 
any cabling. 


3) The maximum cable length is 0.15 m (6 in). The cable length is measured from the card 


connector to the host controller. 0.46 m (18 in) cables are not supported. 


4) The -WAIT and IORDY signals shall be ignored by the host. 


Devices supporting CF Advanced timing modes shall also support slower timing modes, to ensure 
operability with systems that do not support CF Advanced timing modes 
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4.3.8 Ultra DMA Electrical Requirements 


Operation in Ultra DMA mode requires careful attention to cabling, printed circuit board (PCB) 
trace routing and termination for reliable operation. These requirements are described in the 
following sections. 


4.3.8.1 Host and Card signal capacitance limits for Ultra DMA operation 


The host interface signal capacitance at the host connector shall be a maximum of 25 pF for each 
signal as measured at 1 MHz. 


The card interface signal capacitance at the card connector shall be a maximum of 20 pF for 
each signal as measured at 1 MHz. 


4.3.8.2 Series termination required for Ultra DMA operation 


Series termination resistors are required at both the host and the card for operation in any of the 
Ultra DMA modes. Table 13 describes typical values for series termination at the host and the 
device 


Table 13: Typical Series Termination for Ultra DMA 


NOTE -— Only those signals requiring termination are listed in this table. If a signal is not listed, 
series termination is not required for operation in an Ultra DMA mode. shows signals also requiring 
a pull-up or pull-down resistor at the host. The actual termination values should be selected to 
compensate for transceiver and trace impedance to match the characteristic cable impedance. 
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DMARQ 2 VVVV > 


Receiver 


Figure 24: Ultra DMA Termination with Pull-up or Pull down Example 


4.3.8.3 Printed Circuit Board (PCB) Trace Requirements for Ultra DMA 
On any PCB for a host or device supporting Ultra DMA: 


= The longest D[15:00] trace shall be no more than 0.5" longer than either STROBE trace as 
measured from the IC pin to the connector. 


= The shortest D[15:00] trace shall be no more than 0.5" shorter than either STROBE trace as 
measured from the IC pin to the connector. 


4.3.8.4 Ultra DMA Mode Cabling Requirement 


Operation in Ultra DMA mode requires a crosstalk suppressing cable. The cable shall have a 
grounded line between each signal line. 


For True IDE mode operation using a cable with IDE (ATA) type 40 pin connectors it is 
recommended that the host sense the cable type using the method described in the ANSI INCITS 
361-2002 AT Attachment - 6 standard, to prevent use of Ultra DMA with a 40 conductor cable. 


4.3.9 Interface/Bus Timing 


There are two types of bus cycles and timing sequences that occur in the PCMCIA type interface, 
direct mapped I/O transfer and memory access. The two timing sequences are detailed in the 
PCMCIA PC Card Standard. The CompactFlash Storage Card and CF+ Card conform to the 
timing in that reference document. 


4.3.10 Attribute Memory Read Timing Specification 


Attribute Memory access time is defined as 300 ns. Detailed timing specs are shown in Table 14. 
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Table 14: Attribute Memory Read Timing 


Speed Version 

Item Symbol IEEE Symbol 
Read Cycle Time tc(R) tAVAV 
Address Access Time ta(A) tAVQV 
Card Enable Access Time ta(CE) tELQV 
Output Enable Access Time ta(OE) tGLQV 


Output Disable Time from CE tdis(CE) tEHQZ 
Output Disable Time from OE tdis(OE) tGHQZ 
Address Setup Time tsu (A) tAVGL 
Output Enable Time from CE ten(CE) tELQNZ 
Output Enable Time from OE ten(OE) tGLQNZ 
Data Valid from Address Change tv(A) tAXQX 


Note: All times are in nanoseconds. Dout signifies data provided by the CompactFlash Storage Card or CF+ 
Card to the system. The -CE signal or both the -OE signal and the -WE signal shall be de-asserted 
between consecutive cycle operations. 


tdis(CE) 


ten(CE) 


ten(OE) tdis(OE) 


Figure 25: Attribute Memory Read Timing Diagram 
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4.3.11 Configuration Register (Attribute Memory) Write Timing Specification 


The Card Configuration write access time is defined as 250 ns. Detailed timing specifications are 
shown in Table 15. 


Table 15: Configuration Register (Attribute Memory) Write Timing 


[sreedveon SC 
re ee 


: 
: 
: 


Note: All times are in nanoseconds. Din signifies data provided by the system to the CompactFlash Storage 
Card or CF+ Card. 


trec(WE) 


tsu(D-WEH) 


ha 


RE] patainvars PSS 


Figure 26: Configuration Register (Attribute Memory) Write Timing Diagram 
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4.3.12 Common Memory Read Timing Specification 


Table 16: Common Memory Read Timing 


Symbol IEEE 
Symbol 

Output Enable ta(OE) tGLQV 
Access Time 
Output Disable tdis(OE) tGHQZ 
Time from OE 
Address Setup tsu(A) tAVGL 30 
Time 


Address Hold 
Time 


CE Setup 
before OE 


CE Hold 
following OE 


tv(WT-OE) | tGLWTV 
Data Setup for tv(WT) tQVWTH 
Wait Release 


Wait Width tw(WT) tWTLWTH 
Time? 


Notes: 1) -WAIT is not supported in this mode. 
2) The maximum load on -WAIT is 1 LSTTL with 50 pF (40pF below 120nsec Cycle Time) total load. 
All times are in nanoseconds. Dout signifies data provided by the CompactFlash Storage Card or CF+ 
Card to the system. The -WAIT signal may be ignored if the -OE cycle to cycle time is greater than 
the Wait Width time. The Max Wait Width time can be determined from the Card Information 
Structure. The Wait Width time meets the PCMCIA specification of 12us but is intentionally less in this 
specification. 
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Figure 27: Common Memory Read Timing Diagram 
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4.3.13 Common Memory Write Timing Specification 


Table 17: Common Memory Write Timing 


Cycle Time Mode: | 250ns_| 
Symbol IEEE 
Symbol 

Data Setup tsu tDVWH 
before WE (D-WEH) 
Data Hold th(D) tWMDX 30 
following WE 
WE Pulse Width | tw(WE) | tWLWH 7 
Address Setup tsu(A) tAVWL 30 
Time 
CE Setup tsu(CE) tELWL 
before WE 
Write Recovery | trec(WE) tWMAX 30 
Time 
Address Hold th(A tGHAX 20 
Time 
CE Hold th(CE) tGHEH 20 
following WE 


tv t{WLWTV 
(WT-WE) 


WE High from tv(WT) tWTHWH 
Wait Release 


Wait Width tw (WT) tWTLWTH 
Time? 


Notes: 1) -WAIT is not supported in this mode. 


50 
15 
0 


2) The maximum load on -WAIT is 1 LSTTL with 50 pF (40pF below 120nsec Cycle Time) total load. 
All times are in nanoseconds. Din signifies data provided by the system to the CompactFlash Storage 
Card. The -WAIT signal may be ignored if the -WE cycle to cycle time is greater than the Wait Width 
time. The Max Wait Width time can be determined from the Card Information Structure. The Wait 
Width time meets the PCMCIA specification of 12us but is intentionally less in this specification. 
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Figure 28: Common Memory Write Timing Diagram 
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4.3.14 1/0 Input (Read) Timing Specification 
Table 18: I/O Read Timing 


Cycle Time Mode: 
Data Delay after td(IORD) tlIGLQV 100 50 50 45 
IORD 
Data Hold following | th(lORD) tIGHQX 
IORD 


IORD Width Time tw(IORD) |IGLIGH | | 165 | 

Address Setup tsuA(IORD) cus 8] = Ss 

before IORD 

Address Hold thA(IORD) tIGHAX 20 10 10 10 

following |ORD 

CE Setup before tsuCE(IORD) | tELIGL 

IORD 

CE Hold following thCE(IORD) tlGHEH 20 10 10 10 

IORD 

REG Setup before tsuREG tRGLIGL 5 5 5 5 

IORD (IORD) 

REG Hold following thREG tlIGHRGH 

IORD (IORD) 

INPACK Delay tdflINPACK | tIGLIAL 45 na‘ na‘ na‘ 

Falling from IORD® (IORD) 

INPACK Delay tdrINPACK — | tlIGHIAH 45 na‘ na‘ na‘ 

Rising from IORD® (IORD) 

101S16 Delay Falling tdflOlS16 tAVISL 35 

from Address® (ADR) 

101S16 Delay Rising tdrlOlS16 tAVISH 35 

from Address® (ADR) 

Wait Delay Falling tdWT(IORD) | tlGLWTL 35 

from IORD® 
Data Delay { from td(WT) tWTHQV 
Wait Rising’ 


Wait Width Time® tw(WT) tWTLWTH 


Notes:1) -lIOIS16 and -INPACK are not supported in this mode. 


2) -WAIT is not supported in this mode. 


3) Maximum load on -WAIT, -INPACK and -IOIS16 is 1 LSTTL with 50 pF (40pF below 120nsec 
Cycle Time) total load. All times are in nanoseconds. Minimum time from -WAIT high to -IORD high is 
0 nsec, but minimum -IORD width shall still be met. Dout signifies data provided by the 
CompactFlash Storage Card or CF+ Card to the system. Wait Width time meets PCMCIA 
specification of 12us but is intentionally less in this spec. 
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Figure 29: I/O Read Timing Diagram 
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4.3.15 I/O Output (Write) Timing Specification 


Table 19: I/O Write Timing 


j=) 


ol 


Data Setup before tsu(IOWR) tDVIWH 
IOWR 


Data Hold following | th(IOWR) tIWHDX 30 
IOWR 


IOWR Width Time tw(IOWR) tIWLIWH 165 


Address Setup 
before IOWR 


= 


Address Hold 
following |OWR 


CE Setup before tsuCE tELIWL 5 
lIOWR (IOWR) 
CE Hold following thCE tIWHEH 20 
lIOWR (IOWR) 
REG Setup before tsuREG tRGLIWL 
lIOWR (IOWR) 
REG Hold following | thREG tIWHRGH 
lIOWR (IOWR) 
1O1S16 Delay Falling | tdflolS16 tAVISL 
from Address® (ADR) 
1O1S16 Delay Rising | tdrlOIS16 tAVISH 
from Address® (ADR) 
tdWT(IOWR) | tIWLWTL 
IOWR high from tdrlOWR tWTJIWH 
Wait high® (WT) 


Wait Width Time® tw(WT) t{WTLWTH 


Notes: 1) -lIOIS16 and -INPACK are not supported in this mode. 


=) 


i) 
ied) 
iN) 


G 


2) -WAIT is not supported in this mode. 


3) The maximum load on -WAIT, -INPACK, and -IOIS16 is 1 LSTTL with 50 pF (40pF below 120nsec 
Cycle Time) total load. All times are in nanoseconds. Minimum time from -WAIT high to -IOWR high is 
0 nsec, but minimum -IOWR width shall still be met. Din signifies data provided by the system to the 
CompactFlash Storage Card or CF+ Card. The Wait Width time meets the PCMCIA specification of 
12 us but is intentionally less in this specification. 
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Figure 30: I/O Write Timing Diagram 


4.3.16 True IDE PIO Mode Read/Write Timing Specification 
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The timing diagram for True IDE mode of operation in this section is drawn using the conventions 
in the ATA-4 specification, which are different than the conventions used in the PCMCIA 
specification and earlier versions of this specification. Signals are shown with their asserted state 
as high regardless of whether the signal is actually negative or positive true. Consequently, the 
-IORD, the -IOWR and the -IOCS16 signals are shown in the diagram inverted from their 
electrical states on the bus. 


Table 20: True IDE PIO Mode Read/Write Timing 


Cycle time (min) rae 383 


Address Valid to - cI 
IORD/-IOWR setup 
(min) 

-IORD/-IOWR (min) 165 | 125 | | 100 | 


t2 | -IORD/-IOWR (min) 290 290 290 2 SS Ls 
Register (8 bit) 


-IORD/-IOWR 70 25 25 20 
recovery time (min) 

t3 | -IOWR data setup 45 30 30 20 20 15 
(min) 

t4 | -IOWR data hold 30 20 15 10 10 5 5 
(min) 

t5 | -IORD data setup 50 35 20 20 20 15 10 
(min) 
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t6 | -IORD data hold 5 5 5 5 5 5 5 
(min) 

t6Z | -IORD data tristate 30 30 30 30 30 20 20 
(max) 


t7 | Address valid to - 
10CS16 assertion 
(max) 


t8 | Address valid to - 
10CS16 released 
(max) 


t9 | -IORD/-IOWR to 20 15 10 10 10 10 10 
address valid hold 


tRD| Read Data Valid to 
IORDY active (min), 
if IORDY initially low 
after tA 
IORDY Setup time 35 


iB | IORDY Pulse Width | 1250 | 1250 = = = 
(max) 

tC | IORDY assertion to 5 5 5 5 5 na? | na? 
release (max) 


Notes: All timings are in nanoseconds. The maximum load on -lIOCS16 is 1 LSTTL with a 50 pF (40pF 
below 120nsec Cycle Time) total load. All times are in nanoseconds. Minimum time from -IORDY high 
to -IORD high is 0 nsec, but minimum -IORD width shall still be met. 


1) t0 is the minimum total cycle time, t2 is the minimum command active time, and t2i is the minimum 
command recovery time or command inactive time. The actual cycle time equals the sum of the 
actual command active time and the actual command inactive time. The three timing requirements of 
tO, t2, and t2i shall be met. The minimum total cycle time requirement is greater than the sum of t2 
and t2i. This means a host implementation can lengthen either or both t2 or t2i to ensure that tO is 
equal to or greater than the value reported in the device's identify device data. A CompactFlash 
Storage Card implementation shall support any legal host implementation. 


2) This parameter specifies the time from the negation edge of -IORD to the time that the data bus is 
no longer driven by the CompactFlash Storage Card (tri-state). 


3) The delay from the activation of -IORD or -IOWR until the state of IORDY is first sampled. If 
IORDY is inactive then the host shall wait until IORDY is active before the PIO cycle can be 
completed. If the CompactFlash Storage Card is not driving IORDY negated at tA after the activation 
of -IORD or -IOWR, then t5 shall be met and tRD is not applicable. If the CompactFlash Storage Card 
is driving IORDY negated at the time tA after the activation of -IORD or -IOWR, then tRD shall be met 
and t5 is not applicable. 


4) t7 and t8 apply only to modes 0, 1 and 2. For other modes, this signal is not valid. 


5) IORDY is not supported in this mode. 
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— to 
ADDR valid aac 


(A02, A01, A00, -CSO, -CS1) 
(See note 1) 


-IORD / -IOWR 


Write 
Data (D15:D00) - - - - -----------7--------------- < Dace ae sey iy a tole 
(See note 2) 


Read 
Data.(DI5S:D00) HaHa een Ra pee RRR RRR ae < Carrier et rer 
(See note 2) 


-IOCS16 b . 
(See note 3)- -- --------- / a. 


TORDY ttt 
(See note 4, 4-1) <a t 


IORDY XN VY YY YY 5 a Ul cc 
(See note 4, 4-2) : 


IORDY = ------- TY VY VY Y YY YY. eae 
(See note 4, 4-3) .— i 


Notes: 

(1) Device address consists of -CSO, -CS1, and A[02::00] 

(2) Data consists of D[15::00] (16-bit) or D[07::00] (8 bit) 

(3) -IOCS16 is shown for PIO modes 0, 1 and 2. For other modes, this signal is ignored. 

(4) The negation of IORDY by the device is used to extend the PIO cycle. The determination of whether the cycle is to 
be extended is made by the host after tA from the assertion of -IORD or -IOWR. The assertion and negation of IORDY 
is described in the following three cases: 

(4-1) Device never negates IORDY: No wait is generated. 

(4-2) Device starts to drive IORDY low before tA, but causes IORDY to be asserted before tA: No wait generated. 
(4-3) Device drives IORDY low before tA: wait generated. The cycle completes after IORDY is reasserted. For cycles 
where a wait is generated and -IORD is asserted, the device shall place read data on D15-D00 for tRD before causing 
IORDY to be asserted. 


ALL WAVEFORMS IN THIS DIAGRAM ARE SHOWN WITH THE ASSERTED STATE HIGH. 
NEGATIVE TRUE SIGNALS APPEAR INVERTED ON THE BUS RELATIVE TO THE DIAGRAM. 


Figure 31: True IDE PIO Mode Timing Diagram 


4.3.17 True IDE Multiword DMA Mode Read/Write Timing Specification 


The timing diagram for True IDE DMA mode of operation in this section is drawn using the 
conventions in the ATA-4 specification, which are different than the conventions used in the 
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PCMCIA specification and earlier versions of this specification. Signals are shown with their 
asserted state as high regardless of whether the signal is actually negative or positive true. 
Consequently, the -IORD, the -IOWR and the -IOCS16 signals are shown in the diagram 
inverted from their electrical states on the bus. 


Table 21: True IDE Multiword DMA Mode Read/Write Timing 


Mode 0 Mode 1 Mode 2 Mode 3 Mode 4 
(ns) (ns) (ns) (ns) (ns) 


Cycle time (min 


: in) 1 
Fatal All Hl 
(min) 

) 


ti DMACK to -IORD/-IOWR setup 
(min) 


to 
to 
te 
tr 
tc 
ty 


[a0 [as | 


tu CS(1:0) valid to -IORD / -IOWR 


) 
: 
: 


Notes: 1) to is the minimum total cycle time and tp is the minimum command active time, while tkr and tkw 
are the minimum command recovery time or command inactive time for input and output cycles 
respectively. The actual cycle time equals the sum of the actual command active time and the actual 
command inactive time. The three timing requirements of to, tp, tkr, and txw shall be met. The 
minimum total cycle time requirement is greater than the sum of tp and txr or tkw.for input and output 
cycles respectively. This means a host implementation can lengthen either or both of tp and either of 
tkr, and txw as needed to ensure that tp is equal to or greater than the value reported in the device’s 
identify device data. A CompactFlash Storage Card implementation shall support any legal host 
implementation. 


0 
0 
0 


ty 
tkr 
tkw 
tLe 
tlw 


CF+ & CF SPECIFICATION REV. 3.0 © 1998-2004 COMPACTFLASH ASSOCIATION 51 


ELECTRICAL INTERFACE 


== ty Caos = 


-CSO, -CS1 


DMARQ 
(See Note 1) 


-DMACK 
(See Note 2) 


-IORD 
-IOWR 


Read Data 
(D15:D00) 


Dis:Dov) XX XXX XKKEKER KK XXXXXXXXXALE XXXX 


Se (= — 


Notes: 


(1) If the Card cannot sustain continuous, minimum cycle 
time DMA transfers, it may negate DMARQ within the 
time specified from the start of a DMA transfer cycle 
to suspend the DMA transfers in progress and reassert 
the signal at a later time to continue the DMA operation. 


(2) This signal may be negated by the host to suspend 
the DMA transfer in progress. 


ALL WAVEFORMS IN THIS DIAGRAM ARE SHOWN WITH THE ASSERTED STATE HIGH. 
NEGATIVE TRUE SIGNALS APPEAR INVERTED ON THE BUS RELATIVE TO THE DIAGRAM. 


Figure 32: True IDE Multiword DMA Mode Read/Write Timing Diagram 


4.3.18 True IDE Ultra DMA Mode Read/Write Timing Specification 
4.3.18.1 Ultra DMA Overview 


Ultra DMA is an optional data transfer protocol used with the READ DMA, and WRITE DMA, 
commands. When this protocol is enabled, the Ultra DMA protocol shall be used instead of the 
Multiword DMA protocol when these commands are issued by the host. This protocol applies to 
the Ultra DMA data burst only. When this protocol is used there are no changes to other 
elements of the ATA protocol (e.g., Command Block Register access). 


Several signal lines are redefined to provide different functions during an Ultra DMA burst. These 
lines assume these definitions when: 


1. an Ultra DMA mode is selected, and 
2. ahost issues a READ DMA, or a WRITE DMA command requiring data transfer, and 


3. the host asserts -DMACK. 
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These signal lines revert back to the definitions used for non-Ultra DMA transfers upon the 
negation of -DMACK by the host at the termination of an Ultra DMA burst. 


With the Ultra DMA protocol, the STROBE signal that latches data from D[15:00] is generated by 
the same agent (either host or device) that drives the data onto the bus. Ownership of D[15:00] 
and this data strobe signal are given either to the device during an Ultra DMA data-in burst or to 
the host for an Ultra DMA data-out burst. 


During an Ultra DMA burst a sender shall always drive data onto the bus, and, after a sufficient 
time to allow for propagation delay, cable settling, and setup time, the sender shall generate a 
STROBE edge to latch the data. Both edges of STROBE are used for data transfers so that the 
frequency of STROBE is limited to the same frequency as the data. 


Words in the IDENTIFY DEVICE data indicate support of the Ultra DMA feature and the Ultra 
DMA modes the device is capable of supporting. The Set transfer mode subcommand in the SET 
FEATURES command shall be used by a host to select the Ultra DMA mode at which the system 
operates. The Ultra DMA mode selected by a host shall be less than or equal to the fastest mode 
of which the device is capable. Only one Ultra DMA mode shall be selected at any given time. 
All timing requirements for a selected Ultra DMA mode shall be satisfied. Devices supporting any 
Ultra DMA mode shall also support all slower Ultra DMA modes. 


An Ultra DMA capable device shall retain the previously selected Ultra DMA mode after executing 
a software reset sequence or the sequence caused by receipt of a DEVICE RESET command if a 
SET FEATURES disable reverting to defaults command has been issued. The device may revert 
to a Multiword DMA mode if a SET FEATURES enable reverting to default has been issued. An 
Ultra DMA capable device shall clear any previously selected Ultra DMA mode and revert to the 
default non-Ultra DMA modes after executing a power-on or hardware reset. 


Both the host and device perform a CRC function during an Ultra DMA burst. At the end of an 
Ultra DMA burst the host sends its CRC data to the device. The device compares its CRC data 
to the data sent from the host. If the two values do not match, the device reports an error in the 
error register. If an error occurs during one or more Ultra DMA bursts for any one command, the 
device shall report the first error that occurred. If the device detects that a CRC error has 
occurred before data transfer for the command is complete, the device may complete the transfer 
and report the error or abort the command and report the error. 


NOTE - If a data transfer is terminated before completion, the assertion of INTRQ should be 
passed through to the host software driver regardless of whether all data requested by the 
command has been transferred. 


4.3.18.2 Ultra DMA Phases of Operation 


An Ultra DMA data transfer is accomplished through a series of Ultra DMA data-in or data-out 
bursts. Each Ultra DMA burst has three mandatory phases of operation: the initiation phase, the 
data transfer phase, and the Ultra DMA burst termination phase. In addition, an Ultra DMA burst 
may be paused during the data transfer phase (see: 14.3.18.3 Ultra DMA Data Transfer, for the 
detailed protocol descriptions for each of these phases. Table 22: Ultra DMA Data Burst Timing 
Requirements and Table 23: Ultra DMA Data Burst Timing Descriptions define the specific timing 
requirements). In the following rules -DMARDY is used in cases that could apply to either 
-DDMARDY or -HDMARDY, and STROBE is used in cases that could apply to either DSTROBE 
or HSTROBE. The following are general Ultra DMA rules. 


1. An Ultra DMA burst is defined as the period from an assertion of -DMACK by the host to 
the subsequent negation of -DMACK. 
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2. When operating in Ultra DMA modes 2, 1, or 0 a recipient shall be prepared to receive up 
to two data words whenever an Ultra DMA burst is paused. When operating in Ultra 
DMA modes 6, 5, 4, or 3 a recipient shall be prepared to receive up to three data words 
whenever an Ultra DMA burst is paused. 


4.3.18.2.1 Ultra DMA Burst Initiation Phase Rules 


1. An Ultra DMA burst initiation phase begins with the assertion of DMARQ by a device and 
ends when the sender generates a STROBE edge to transfer the first data word. 


2. An Ultra DMA burst shall always be requested by a device asserting DMARQ. 


3. When ready to initiate the requested Ultra DMA burst, the host shall respond by asserting 
-DMACK. 


4. Ahost shall never assert -DMACK without first detecting that DMARQ is asserted. 


5. For Ultra DMA data-in bursts: a device may begin driving D[15:00] after detecting that 
-DMACK is asserted, STOP negated, and -HDMARDY is asserted. 


6. After asserting DMARQ or asserting -DDMARDY for an Ultra DMA data-out burst, a 
device shall not negate either signal until the first STROBE edge is generated. 


7. After negating STOP or asserting -HDMARDY for an Ultra DMA data-in burst, a host shall 
not change the state of either signal until the first STROBE edge is generated. 


4.3.18.2.2 Ultra DMA Data transfer phase rules 


1. The data transfer phase is in effect from after Ultra DMA burst initiation until Ultra DMA 
burst termination. 


2. A recipient pauses an Ultra DMA burst by negating -DMARDY and resumes an Ultra 
DMA burst by reasserting -DMARDY. 


3. A sender pauses an Ultra DMA burst by not generating STROBE edges and resumes by 
generating STROBE edges. 


4. A recipient shall not signal a termination request immediately when the sender stops 
generating STROBE edges. In the absence of a termination from the sender the 
recipient shall always negate -DMARDY and wait the required period before signaling a 
termination request. 


5. Asender may generate STROBE edges at greater than the minimum period specified by 
the enabled Ultra DMA mode. The sender shall not generate STROBE edges at less than 
the minimum period specified by the enabled Ultra DMA mode. A recipient shall be able 
to receive data at the minimum period specified by the enabled Ultra DMA mode. 


4.3.18.2.3 Ultra DMA Burst Termination Phase Rules 
1. Either a sender or a recipient may terminate an Ultra DMA burst. 


2. Ultra DMA burst termination is not the same as command completion. If an Ultra DMA 
burst termination occurs before command completion, the command shall be completed 
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by initiation of a new Ultra DMA burst at some later time or aborted by the host issuing a 
hardware or software reset or DEVICE RESET command if implemented by the device. 


3. An Ultra DMA burst shall be paused before a recipient requests a termination. 


4. A host requests a termination by asserting STOP. A device acknowledges a termination 
request by negating DMARQ. 


5. A device requests a termination by negating DMARQ. A host acknowledges a 
termination request by asserting STOP. 


6. Once a sender requests a termination, the sender shall not change the state of STROBE 
until the recipient acknowledges the request. Then, if STROBE is not in the asserted 
state, the sender shall return STROBE to the asserted state. No data shall be transferred 
on this transition of STROBE. 


7. A sender shall return STROBE to the asserted state whenever the sender detects a 
termination request from the recipient. No data shall be transferred nor CRC calculated 
on this edge of DSTROBE. 


8. Once a recipient requests a termination, the responder shall not change DMARDY from 
the negated state for the remainder of an Ultra DMA burst. 


9. Arecipient shall ignore a STROBE edge when DMAR@ is negated or STOP is asserted. 


4.3.18.3 Ultra DMA Data Transfers Timing 
Table 22 and Table 23 define the timings associated with all phases of Ultra DMA bursts. 
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Table 22: Ultra DMA Data Burst Timing Requirements 


UDMA UDMA UDMA UDMA UDMA Measurement location 
Mode 0 Mode 1 Mode 2 Mode 3 Mode 4 (See Note 2) 
(ns) (ns) (ns) (ns) 
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_) 
n 

~~ 


n 
o) 
=} 
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0) 
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Zz 
ie) 
=< 
(0) 
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rool [esol | 
rez [ezl | 
rot fol | 


ae 
oO 
oO 


j=) 


ol 


Recipient 


oO 


0 
co) 
=: 
ro) 
co) 


ie) 
o) 
=| 
Q 
o) 
s 


bed 
fea 
La] 
i 
fl 
ai 
hdl 
zl 
anal 
ia] 
toll 
= 
il 
100 | 
eal 
se 
(emi 
mal 
| 60 | 
= 
al 
= 
aes 


Notes: 1) All timing measurement switching points (low to high and high to low) shall be taken at 1.5 V. 
2) All signal transitions for a timing parameter shall be measured at the connector specified in the 
measurement location column. For example, in the case of tars, both STROBE and -DMARDY 
transitions are measured at the sender connector. 


3) The parameter tcyc shall be measured at the recipient's connector farthest from the sender. 
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4) The parameter t,; shall be measured at the connector of the sender or recipient that is responding 
to an incoming transition from the recipient or sender respectively. Both the incoming signal and the 
outgoing response shall be measured at the same connector. 


5)The parameter taz shall be measured at the connector of the sender or recipient that is driving the 
bus but must release the bus the allow for a bus turnaround. 


6) See the AC Timing requirements in Table 25: Ultra DMA AC Signal Requirements. 
Table 23: Ultra DMA Data Burst Timing Descriptions 


tecyctyp_ | Typical sustained average two cycle time 


tcyc Cycle time allowing for asymmetry and clock variations (from STROBE edge to STROBE 
edge) 

tecyc Two cycle time allowing for clock variations (from rising edge to next rising edge or from 
falling edge to next falling edge of STROBE) 


i) 
ol 


a 2 ; 
CH i i 
; : aa ion) 
; ; : invalid) 


t 
t 


tzrs Time from STROBE output released-to-driving until the first transition of critical timing. 


t 
t 


tozFs Time from data output released-to-driving until the first transition of critical timing. 


Limiediietocktine 
er | | 
) 


tes 
tu 


tenv Envelope time (from -DMACK to STOP and -HDMARDY during data in burst initiation and 
from DMACK to STOP during data out burst initiation) 


trFs Ready-to-final-STROBE time (no STROBE edges shall be sent this long after negation of 
-DMARDY) 


trp Ready-to-pause time (that recipient shall wait to pause after negating -DMARDY 
SS 


tlorpyz Maximum time before releasing IORDY 


ing - ) 
tziorDY Minimum time before driving IORDY 4 
tack Setup and hold times for -DMACK (before assertion or negation) 


Time from STROBE edge to negation of DMARQ or assertion of STOP (when sender 
terminates a burst) 
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Notes: 1) The parameters tu), tui (in Figure 36: Ultra DMA Data-In Burst Device Termination Timing and 


Figure 37: Ultra DMA Data-In Burst Host Termination Timing), and ti indicate sender-to-recipient or 
recipient-to-sender interlocks, i.e., one agent (either sender or recipient) is waiting for the other agent 
to respond with a signal before proceeding. tu: is an unlimited interlock that has no maximum time 
value. tm is a limited time-out that has a defined minimum. t, is a limited time-out that has a defined 
maximum. 


2) 80-conductor cabling (see 4.3.8.4) shall be required in order to meet setup (tps, tes) and hold (tpn, 
tcu) times in modes greater than 2. 


3) Timing for tpvs, tovy, tevs and tcvy shall be met for lumped capacitive loads of 15 and 40 pF at the 
connector where the Data and STROBE signals have the same capacitive load value. Due to 
reflections on the cable, these timing measurements are not valid in a normally functioning system. 


4) For all modes the parameter tziorpy may be greater than tenv due to the fact that the host has a 
pull-up on IORDY- giving it a known state when released. 


5) The parameters tps, and tpy for mode 5 are defined for a recipient at the end of the cable only ina 
configuration with a single device located at the end of the cable. This could result in the minimum 
values for tps and tpy for mode 5 at the middle connector being 3.0 and 3.9 ns respectively. 


Table 24: Ultra DMA Sender and Recipient IC Timing Requirements 


Comments 


Recipient IC data setup time (from | 14.7 9.7 48 
data valid until STROBE edge) 
(see note 2) 


Recipient IC data hold time (from | 4.8 4.8 4.8 4.8 4.8 
STROBE edge until data may 

become invalid) (see note 2) 

Sender IC data valid setup time 72.9 50.9 33.9 22.6 9.5 
(from data valid until STROBE 

edge) (see note 3) 

Sender IC data valid hold time 

(from STROBE edge until data 

may become invalid) (see note 3) 


Notes: 1) All timing measurement switching points(low to high and high to low) shall be taken at 1.5 V. 


2) The correct data value shall be captured by the recipient given input data with a slew rate of 0.4 
V/ns rising and falling and the input STROBE with a slew rate of 0.4 V/ns rising and falling at tpsic and 
tonic timing (as measured through 1.5 V). 


3) The parameters tpvsic and tpvuic shall be met for lumped capacitive loads of 15 and 40 pF at the IC 
where all signals have the same capacitive load value. Noise that may couple onto the output signals 
from external sources has not been included in these values. 
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Table 25: Ultra DMA AC Signal Requirements 


Name Comment 
[V/ns] | [V/ns] 


SRIsE Rising Edge Slew Rate for any signal 1.25 


SFALL Fa 


Note: 


lling Edge Slew Rate for any signal 1.25 


1) The sender shall be tested while driving an 18 inch long, 80 conductor cable with PVC insulation 
material. The signal under test shall be cut at a test point so that it has not trace, cable or recipient 
loading after the test point. All other signals should remain connected through to the recipient. The 
test point may be located at any point between the sender’s series termination resistor and one half 
inch or less of conductor exiting the connector. If the test point is on a cable conductor rather than 
the PCB, an adjacent ground conductor shall also be cut within one half inch of the connector. 


The test load and test points should then be soldered directly to the exposed source side connectors. 
The test loads consist of a 15 pF or a 40 pF, 5%, 0.08 inch by 0.05 inch surface mount or smaller size 
capacitor from the test point to ground. Slew rates shall be met for both capacitor values. 


Measurements shall be taken at the test point using a <1 pF, >100 Kohm, 1 Ghz or faster probe and 
a 500 MHz or faster oscilloscope. The average rate shall be measured from 20% to 80% of the 
settled Von level with data transitions at least 120 nsec apart. The settled Von level shall be 
measured as the average output high level under the defined testing conditions from 100 nsec after 
80% of a rising edge until 20% of the subsequent falling edge. 


4.3.18.3.1 Initiating an Ultra DMA Data-In Burst 


a) 


An Ultra DMA Data-In burst is initiated by following the steps lettered below. The timing 
diagram is shown in Figure 33: Ultra DMA Data-In Burst Initiation Timing. The associated 
timing parameters are specified in Table 22: Ultra DMA Data Burst Timing Requirements 
and are described in Table 23: Ultra DMA Data Burst Timing Descriptions. 


The following steps shall occur in the order they are listed unless otherwise specifically 
allowed: 


The host shall keep -DMACK in the negated state before an Ultra DMA burst is initiated. 


The device shall assert DMARQ to initiate an Ultra DMA burst. After assertion of DUARQ 
the device shall not negate DMARQ until after the first negation of DSTROBE. 


Steps (c), (d), and (e) may occur in any order or at the same time. The host shall assert 
STOP. 


The host shall negate -HDMARDY. 


The host shall negate -CSO, -CS1, DA2, DA1, and DAO. The host shall keep -CSO, -CS1, 
DA2, DA1, and DAO negated until after negating -DMACK at the end of the burst. 


Steps (c), (d), and (e) shall have occurred at least tack before the host asserts -DMACK. 
The host shall keep -DMACK asserted until the end of an Ultra DMA burst. 


The host shall release D[15:00] within taz after asserting -DMACK. 
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j) The device may assert DSTROBE tziorpy after the host has asserted -DMACK. Once the 
device has driven DSTROBE the device shall not release DSTROBE until after the host 
has negated -DMACK at the end of an Ultra DMA burst. 


k) The host shall negate STOP and assert -HDMARDY within tenv after asserting -DMACK. 
After negating STOP and asserting -HDMARDY, the host shall not change the state of 
either signal until after receiving the first transition of DSTROBE from the device (i.e., 
after the first data word has been received). 


1) The device shall drive D[15:00] no sooner than tzap after the host has asserted -DMACK, 
negated STOP, and asserted -HDMARDY. 


m) The device shall drive the first word of the data transfer onto D[15:00]. This step may 
occur when the device first drives D[15:00] in step (j). 


n) To transfer the first word of data the device shall negate DSTROBE within trs after the 
host has negated STOP and asserted -HDMARDY. The device shall negate DSTROBE 
no sooner than tovs after driving the first word of data onto D[15:00]. 


DMARQ 
(device) ‘ 
tur ——> 
OMe CC -—~—“—s—~—SSOSS SS —“—S 
(host) 


> 


STOP 
(host) 


-HDMARDY 
(host) 


(device) 


Data 
D15:D00 


AO0, A01, Ad2, 
-CSO, -CS1 


Notes:The definitions for the IORDY:-DDMARDY:DSTROBE, -IORD: -HDMARDY:HSTROBE, and 
-IOWR:STOP signal lines are not in effect until DMARQ and -DMACK are asserted. 


Figure 33: Ultra DMA Data-In Burst Initiation Timing 
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4.3.18.3.2 Sustaining an Ultra DMA Data-In Burst 


An Ultra DMA Data-In burst is sustained by following the steps lettered below. The timing diagram 
is shown in Figure 34: Sustained Ultra DMA Data-In Burst Timing. The timing parameters are 
specified in Table 22: Ultra DMA Data Burst Timing Requirements and are described in Table 23: 
Ultra DMA Data Burst Timing Descriptions. 


The following steps shall occur in the order they are listed unless otherwise specifically allowed: 
a) The device shall drive a data word onto D[15:00]. 


b) The device shall generate a DSTROBE edge to latch the new word no sooner than tDVS 
after changing the state of D[15:00]. The device shall generate a DSTROBE edge no 
more frequently than tCYC for the selected Ultra DMA mode. The device shall not 
generate two rising or two falling DSTROBE edges more frequently than 2tcyc for the 
selected Ultra DMA mode. 


c) The device shall not change the state of D[15:00] until at least tDVH after generating a 
DSTROBE edge to latch the data. 


d) The device shall repeat steps (a), (b), and (c) until the data transfer is complete or an 
Ultra DMA burst is paused, whichever occurs first. 


>| 


tcve ————> 


DSTROBE 
at device 


tovs _,| 
Data tovsic tovsic 

(D15:D00) 

at device 


DSTROBE 
at host 


Data 
(D15:D00) 


at host XXXXXKX XK KKXKK XKXKKKXKK 


Notes: D[15:00] and DSTROBE signals are shown at both the host and the device to emphasize 
that cable settling time as well as cable propagation delay shall not allow the data signals to 
be considered stable at the host until some time after they are driven by the device. 


Figure 34: Sustained Ultra DMA Data-In Burst Timing 


4.3.18.3.3 Host Pausing an Ultra DMA Data-In Burst 
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The host pauses a Data-In burst by following the steps lettered below. A timing diagram is shown 
in Figure 35: Ultra DMA Data-In Burst Host Pause Timing. The timing parameters are specified in 
Table 22: Ultra DMA Data Burst Timing Requirements and are described in Table 23: Ultra DMA 
Data Burst Timing Descriptions. 


The following steps shall occur in the order they are listed unless otherwise specifically allowed: 


DMARQ 
(device) 


-DMACK 


(host) 


STOP 
(host) 


-HDMARDY 


(host) 


The host shall not pause an Ultra DMA burst until at least one data word of an Ultra DMA 
burst has been transferred. 


The host shall pause an Ultra DMA burst by negating -HDMARDY. 


The device shall stop generating DSTROBE edges within trrs of the host negating 
-HDMARDY. 


If the host negates -HDMARDY within tsr after the device has generated a DSTROBE 
edge, then the host shall be prepared to receive zero or one additional data words. If the 
host negates -HDMARDY greater than tsr after the device has generated a DSTROBE 
edge, then the host shall be prepared to receive zero, one or two additional data words. 
The additional data words are a result of cable round trip delay and tres timing for the 
device. 


The host shall resume an Ultra DMA burst by asserting -HDMARDY. 


DSTROBE 


(device) 


Data 


(D15:D00) 
(device) 


Notes: 1) The host may assert STOP to request termination of the Ultra DMA burst no sooner than trp after 
-HDMARDY is negated. 


2) After negating -HDMARDY, the host may receive zero, one, two, or three more data words from 
the device. 


Figure 35: Ultra DMA Data-In Burst Host Pause Timing 


4.3.18.3.4 Device Terminating an Ultra DMA Data-In Burst 
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The device terminates an Ultra DMA Data-In burst by following the steps lettered below. The 
timing diagram is shown in Figure 36: Ultra DMA Data-In Burst Device Termination Timing. The 
timing parameters are specified in Table 22: Ultra DMA Data Burst Timing Requirements and are 
described in Table 23: Ultra DMA Data Burst Timing Descriptions. 


The following steps shall occur in the order they are listed unless otherwise specifically allowed: 


a) The device shall not pause an Ultra DMA burst until at least one data word of an Ultra 
DMA burst has been transferred. 


b) The device shall pause an Ultra DMA burst by not generating DSTROBE edges. 


c) NOTE -—The host shall not immediately assert STOP to initiate Ultra DMA burst 
termination when the device stops generating STROBE edges. If the device does not 
negate DMARQ, in order to initiate ULTRA DMA burst termination, the host shall negate 
-HDMARDY and wait tre before asserting STOP. 


d) The device shall resume an Ultra DMA burst by generating a DSTROBE edge. 


DMARQ 
(device) 


-DMACK 
(host) 


STOP 
(host) 


-HDMARDY 


(host) 


DSTROBE 
(device) 


Data 
(D15:D00) 


AO0, A01, A02, 
-CSO, -CS1 


Notes: The definitions for the STOP, HDMARDY, and DSTROBE signal lines are no longer in effect after 
DMARQ and DMACK are negated. 


Figure 36: Ultra DMA Data-In Burst Device Termination Timing 


4.3.18.3.5 Host Terminating an Ultra DMA Data-In Burst 
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The host terminates an Ultra DMA Data-In burst by following the steps lettered below. The timing 
diagram is shown in Figure 37: Ultra DMA Data-In Burst Host Termination Timing. The timing 
parameters are specified in Table 22: Ultra DMA Data Burst Timing Requirements and are 
described in Table 23: Ultra DMA Data Burst Timing Descriptions. 


The following steps shall occur in the order they are listed unless otherwise specifically allowed: 


a) 


b) 


The host shall not initiate Ultra DMA burst termination until at least one data word of an 
Ultra DMA burst has been transferred. 


The host shall initiate Ultra DMA burst termination by negating -HDMARDY. The host 
shall continue to negate -HDMARDY until the Ultra DMA burst is terminated. 


The device shall stop generating DSTROBE edges within trrs of the host negating 
-HDMARDY 


If the host negates -HDMARDY within tsr after the device has generated a DSTROBE 
edge, then the host shall be prepared to receive zero or one additional data words. If the 
host negates HDMARDYgreater than tsr after the device has generated a DSTROBE 
edge, then the host shall be prepared to receive zero, one or two additional data words. 
The additional data words are a result of cable round trip delay and tres timing for the 
device. 


The host shall assert STOP no sooner than tre after negating -HDMARDY. The host shall 
not negate STOP again until after the Ultra DMA burst is terminated. 


The device shall negate DMARQ within tu after the host has asserted STOP. The device 
shall not assert DMARQ again until after the Ultra DMA burst is terminated. 


If DSTROBE is negated, the device shall assert DSTROBE within tu after the host has 
asserted STOP. No data shall be transferred during this assertion. The host shall ignore 
this transition on DSTROBE. DSTROBE shall remain asserted until the Ultra DMA burst 
is terminated. 


The device shall release D[15:00] no later than t az after negating DMARQ. 


The host shall drive DD D[15:00] no sooner than tzaH after the device has negated 
DMARQ. For this step, the host may first drive D[15:00] with the result of its CRC 
calculation (see 9.15). 


If the host has not placed the result of its CRC calculation on D[15:00] since first driving 
D[15:00] during (9), the host shall place the result of its CRC calculation on D[15:00] 
(see 9.15). 


The host shall negate -DMACK no sooner than tmu after the device has asserted 
DSTROBE and negated DMARQ and the host has asserted STOP and negated 
-HDMARDY, and no sooner than tovs after the host places the result of its CRC 
calculation on D[15:00]. 


The device shall latch the hosts CRC data from D[15:00] on the negating edge of 
-DMACK. 


The device shall compare the CRC data received from the host with the results of its own 
CRC calculation. If a miscompare error occurs during one or more Ultra DMA burst for 
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any one command, at the end of the command, the device shall report the first error that 
occurred (see 9.15) 


n) The device shall release DSTROBE within tiorpyz after the host negates -DMACK. 


0) The host shall neither negate STOP nor assert -HDMARDY until at least tack after the 
host has negated -DMACK. 


p) The host shall not assert -IORD, -CSO, -CS1, DA2, DA1, or DAO until at least tack after 
negating DMACK. 


DMARQ 
(device) 


-DMACK 
(host) 


STOP 
(host) 


-HDMARDY 


(host) 


DSTROBE 
(device) 


Data 
D15:D00 


AO0, A01, A02, 
-CSO, -CS1 


Notes: The definitions for the STOP, HDMARDY, and DSTROBE signal lines are no longer in effect after 
DMARQ and DMACK are negated.. 


Figure 37: Ultra DMA Data-In Burst Host Termination Timing 


4.3.18.3.6 Initiating an Ultra DMA Data-Out Burst 
An Ultra DMA Data-out burst is initiated by following the steps lettered below. The timing diagram 
is shown in Figure 38: Ultra DMA Data-Out Burst Initiation Timing. The timing parameters are 


specified in Table 22: Ultra DMA Data Burst Timing Requirements and are described in Table 23: 
Ultra DMA Data Burst Timing Descriptions. 
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The following steps shall occur in the order they are listed unless otherwise specifically allowed: 


The host shall keep -DMACK in the negated state before an Ultra DMA burst is initiated. 
The device shall assert DMARQ to initiate an Ultra DMA burst. 


Steps (c), (d), and (e) may occur in any order or at the same time. The host shall assert 
STOP. 


The host shall assert HSTROBE. 


The host shall negate -CSO, -CS1, DA2, DA1, and DAO. The host shall keep -CSO, -CS1, 
DA2, DA1, and DAO negated until after negating -DMACK at the end of the burst. 


Steps (c), (d), and (e) shall have occurred at least tack before the host asserts -DMACK. 
The host shall keep -DMACK asserted until the end of an Ultra DMA burst. 


The device may negate -DDMARDY tziorpy after the host has asserted -DMACK. Once 
the device has negated -DDMARDY, the device shall not release -DDMARDY until after 
the host has negated DMACK at the end of an Ultra DMA burst. 


The host shall negate STOP within tenv after asserting -DMACK. The host shall not assert 
STOP until after the first negation of HSTROBE. 


The device shall assert -DDMARDY within tu after the host has negated STOP. After 
asserting DMARQ and -DDMARDY the device shall not negate either signal until after the 
first negation of HSTROBE by the host. 


The host shall drive the first word of the data transfer onto D[15:00]. This step may occur 
any time during Ultra DMA burst initiation. 


To transfer the first word of data: the host shall negate HSTROBE no sooner than tui after 


the device has asserted -DDMARDY. The host shall negate HSTROBE no sooner than 
tovs after the driving the first word of data onto D[15:00]. 
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DMARQ 
(device) 


-DMACK 
(host) 


STOP 
(host) 


-DDMARDY 
(device) 


HSTROBE 
(host) 


Data 
D15:D00 
(host) < 


AO0, A01, A02, 
-CSO, -CS1 


Note: The definitions for the STOP, DDMARDY, and HSTROBE signal lines are not in effect until DMARQ 
and DMACK are asserted. 


Figure 38: Ultra DMA Data-Out Burst Initiation Timing 


4.3.18.3.7 Sustaining an Ultra DMA Data-Out Burst 


An Ultra DMA Data-Out burst is sustained by following the steps lettered below. The timing 
diagram is shown in Figure 39: Sustained Ultra DMA Data-Out Burst Timing. The associated 
timing parameters are specified in Table 22: Ultra DMA Data Burst Timing Requirements and are 
described in Table 23: Ultra DMA Data Burst Timing Descriptions. 


The following steps shall occur in the order they are listed unless otherwise specifically allowed: 

a) The host shall drive a data word onto D[15:00]. 

b) The host shall generate an HSTROBE edge to latch the new word no sooner than tovs 
after changing the state of D[15:00]. The host shall generate an HSTROBE edge no more 
frequently than tcyc for the selected Ultra DMA mode. The host shall not generate two 
rising or falling HSTROBE edges more frequently than 2tcyc for the selected Ultra DMA 


mode. 


c) The host shall not change the state of D[15:00] until at least tov after generating an 
HSTROBE edge to latch the data. 
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d) The host shall repeat steps (a), (b), and (c) until the data transfer is complete or an Ultra 
DMA burst is paused, whichever occurs first. 


tocve >| 


teyce > teye —_—> 


le tocyc 
HSTROBE 
at host 


tovu tovu tovu 
tov tovs tov tovs tov 
tovsic tovsic 


Data 
(D15:D00) 
at host 


HSTROBE 
at device 


Data 
(D15:D00) 


at device KKK LOOOOOCODXY KOOOOXOEKE 


Note: Data (D15:D00) and HSTROBE signals are shown at both the device and the host to emphasize that 
cable settling time as well as cable propagation delay shall not allow the data signals to be 
considered stable at the device until some time after they are driven by the host. 


2) 


Figure 39: Sustained Ultra DMA Data-Out Burst Timing 


4.3.18.3.8 Device Pausing an Ultra DMA Data-Out Burst 


The device pauses an Ultra DMA Data-Out burst by following the steps lettered below. The 
timing diagram is shown in Figure 40: Ultra DMA Data-Out Burst Device Pause Timing. The 
timing parameters are specified in Table 22: Ultra DMA Data Burst Timing Requirements and are 
described in Table 23: Ultra DMA Data Burst Timing Descriptions. 


The following steps shall occur in the order they are listed unless otherwise specifically allowed: 


a) The device shall not pause an Ultra DMA burst until at least one data word of an Ultra 
DMA burst has been transferred. 


b) The device shall pause an Ultra DMA burst by negating -DDMARDY. 


c) The host shall stop generating HSTROBE edges within trrs of the device negating 
-DDMARDY. 


d) If the device negates -DDMARDY within tsr after the host has generated an HSTROBE 
edge, then the device shall be prepared to receive zero or one additional data words. If 
the device negates -DDMARDY greater than tsr after the host has generated an 
HSTROBE edge, then the device shall be prepared to receive zero, one or two additional 
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data words. The additional data words are a result of cable round trip delay and trrs 
timing for the host. 


e) The device shall resume an Ultra DMA burst by asserting -DDMARDY. 


DMARQ 
(device) 


-DMACK 
(host) 


STOP 
(host) 


-DDMARDY 
(device) 


HSTROBE 
(host) 


Data 
D15:D00 
(host) 


Notes: 1) The device may negate DMARQ to request termination of the Ultra DMA burst no sooner than tre 
after -DDMARDY is negated. 


2) After negating -DDMARDY, the device may receive zero, one, two, or three more data words from 
the host. 


Figure 40: Ultra DMA Data-Out Burst Device Pause Timing 


4.3.18.3.9 Device Terminating an Ultra DMA Data-Out Burst 


The device terminates an Ultra DMA Data-Out burst by following the steps lettered below. The 
timing diagram for the operation is shown in Figure 41: Ultra DMA Data-Out Burst Device 
Termination Timing. The timing parameters are specified in Table 22: Ultra DMA Data Burst 
Timing Requirements and are described in Table 23: Ultra DMA Data Burst Timing Descriptions. 


The following steps shall occur in the order they are listed unless otherwise specifically allowed: 


a) The device shall not initiate Ultra DMA burst termination until at least one data word of an 
Ultra DMA burst has been transferred. 


b) The device shall initiate Ultra DMA burst termination by negating -DDMARDY. 


c) The host shall stop generating an HSTROBE edges within trrs of the device negating 
-DDMARDY. 


d) If the device negates -DDMARDY within tsr after the host has generated an HSTROBE 


edge, then the device shall be prepared to receive zero or one additional data words. If 
the device negates -DDMARDY greater than tsr after the host has generated an 
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HSTROBE edge, then the device shall be prepared to receive zero, one or two additional 
data words. The additional data words are a result of cable round trip delay and trrs 
timing for the host. 


The device shall negate DMARQ no sooner than tre after negating -DDMARDY. The 
device shall not assert DMARQ again until after the Ultra DMA burst is terminated. 


The host shall assert STOP within tu after the device has negated DMARQ. The host 
shall not negate STOP again until after the Ultra DMA burst is terminated. 


If HSTROBE is negated, the host shall assert HSTROBE within tu after the device has 
negated DMARQ. No data shall be transferred during this assertion. The device shall 
ignore this transition of HSTROBE. HSTROBE shall remain asserted until the Ultra DMA 
burst is terminated. 


The host shall place the result of its CRC calculation on D[15:00] (see 9.15). 

The host shall negate -DMACK no sooner than tau after the host has asserted HSTROBE 
and STOP and the device has negated DMARQ and -DDMARDY, and no sooner than 
tovs after placing the result of its CRC calculation on D[15:00]. 


The device shall latch the hosts CRC data from D[15:00] on the negating edge of 
-DMACK. 


The device shall compare the CRC data received from the host with the results of its own 


CRC calculation. If a miscompare error occurs during one or more Ultra DMA bursts for 
any one command, 
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Note: The definitions for the STOP, DDMARDY, and HSTROBE signal lines are no longer in effect after 
DMARQ and DMACK are negated. 


4.3.18.3.10 Host 


Figure 41: Ultra DMA Data-Out Burst Device Termination Timing 


Terminating an Ultra DMA Data-Out Burst 


Termination of an Ultra DMA Data-Out burst by the host is shown in Figure 42: Ultra DMA Data- 
Out Burst Host Termination Timing while timing parameters are specified in Table 22: Ultra DMA 
Data Burst Timing Requirements and timing parameters are described in Table 23: Ultra DMA 


Data Bu 


rst Timing Descriptions. 


The following steps shall occur in the order they are listed unless otherwise specifically allowed: 


a) 


b) 


The host shall initiate termination of an Ultra DMA burst by not generating HSTROBE 
edges. 


The host shall assert STOP no sooner than tss after it last generated an HSTROBE edge. 
The host shall not negate STOP again until after the Ultra DMA burst is terminated. 


CF+ & CF SPECIFICATION REV. 3.0 © 1998-2004 COMPACTFLASH ASSOCIATION 71 


ELECTRICAL INTERFACE 


72 


The device shall negate DMARQ within ti after the host asserts STOP. The device shall 
not assert DMARQ again until after the Ultra DMA burst is terminated. 


The device shall negate -DDMARDY within tu after the host has negated STOP. The 
device shall not assert -DDMARDY again until after the Ultra DMA burst termination is 
complete. 


If HSTROBE is negated, the host shall assert HSTROBE within tu after the device has 
negated DMARQ. No data shall be transferred during this assertion. The device shall 
ignore this transition on HSTROBE. HSTROBE shall remain asserted until the Ultra DMA 
burst is terminated. 


The host shall place the result of its CRC calculation on D[15:00] (see 9.15). 

The host shall negate -DMACK no sooner than tuu after the host has asserted HSTROBE 
and STOP and the device has negated DMARQ and -DDMARDY, and no sooner than 
tovs after placing the result of its CRC calculation on D[15:00]. 


The device shall latch the host's CRC data from D[15:00] on the negating edge of 
-DMACK. 


The device shall compare the CRC data received from the host with the results of its own 
CRC calculation. If a miscompare error occurs during one or more Ultra DMA bursts for 
any one command, at the end of the command, the device shall report the first error that 
occurred (see 9.15). 

The device shall release -DDMARDY within t iorpyz after the host has negated -DMACK. 


The host shall neither negate STOP nor negate HSTROBE until at least tack after 
negating -DMACK. 


The host shall not assert -IOWR, -CSO, -CS1, DA2, DA1, or DAO until at least tack after 
negating -DMACK. 
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Notes: The definitions for the STOP, DDMARDY, and HSTROBE signal lines are no longer in effect after 


DMARQ and DMACK are negated. 


Figure 42: Ultra DMA Data-Out Burst Host Termination Timing 


4.3.18.4 Ultra DMA CRC Calculation 


The following is a list of rules for calculating CRC, determining if a CRC error has occurred during 
an Ultra DMA burst, and reporting any error that occurs at the end of a command. 


1. 


2. 


Both the host and the device shall have a 16-bit CRC calculation function. 
Both the host and the device shall calculate a CRC value for each Ultra DMA burst. 


The CRC function in the host and the device shall be initialized with a seed of 4ABAh at the 
beginning of an Ultra DMA burst before any data is transferred. 


For each STROBE transition used for data transfer, both the host and the device shall 
calculate a new CRC value by applying the CRC polynomial to the current value of their 
individual CRC functions and the word being transferred. CRC is not calculated for the return 
of STROBE to the asserted state after the Ultra DMA burst termination request has been 
acknowledged. 


At the end of any Ultra DMA burst the host shall send the results of its CRC calculation 
function to the device on D[15:00] with the negation of -DMACK. 
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6. 


10. 


11. 


The device shall then compare the CRC data from the host with the calculated value in its 
own CRC calculation function. If the two values do not match, the device shall save the error 
and report it at the end of the command. A subsequent Ultra DMA burst for the same 
command that does not have a CRC error shall not clear an error saved from a previous Ultra 
DMA burst in the same command. If a miscompare error occurs during one or more Ultra 
DMA bursts for any one command, at the end of the command, the device shall report the 
first error that occurred. 


For READ DMA, WRITE DMA, READ DMA QUEUED, or WRITE DMA QUEUED commands: 
When a CRC error is detected, it shall be reported by setting both ICRC and ABRT (bit 7 and 
bit 2 in the Error register) to one. ICRC is defined as the “Interface CRC Error” bit. The host 
shall respond to this error by re-issuing the command. 


For a REQUEST SENSE packet command (see SPC 110/955D for definition of the 
REQUEST SENSE command): When a CRC error is detected during transmission of sense 
data the device shall complete the command and set CHK to one. The device shall report a 
Sense key of OBh (ABORTED COMMAND). The device shall preserve the original sense 
data that was being returned when the CRC error occurred. The device shall not report any 
additional sense data specific to the CRC error. The host device driver may retry the 
REQUEST SENSE command or may consider this an unrecoverable error and retry the 
command that caused the Check Condition. 


For any packet command except a REQUEST SENSE command: If a CRC error is detected, 
the device shall complete the command with CHK set to one. The device shall report a Sense 
key of 04h (HARDWARE ERROR). The sense data supplied via a subsequent REQUEST 
SENSE command shall report an ASC/ASCQ value of O8h/03h (LOGICAL UNIT 
COMMUNICATION CRC ERROR). Host drivers should retry the command that resulted in a 
HARDWARE ERROR. 


NOTE - If excessive CRC errors are encountered while operating in Ultra mode 2 or 1, the 
host should select a slower Ultra mode. Caution: CRC errors are detected and reported only 
while operating in an Ultra mode. 


A host may send extra data words on the last Ultra DMA burst of a data out command. If a 
device determines that all data has been transferred for a command, the device shall 
terminate the burst. A device may have already received more data words than were required 
for the command. These extra words are used by both the host and the device to calculate 
the CRC, but, on an Ultra DMA data out burst, the extra words shall be discarded by the 
device. 


The CRC generator polynomial is: G(X) = X16 + X12 + X5 + 1. Table 28 describes the 
equations for 16-bit parallel generation of the resulting polynomial (based on a word 
boundary). 


NOTE - Since no bit clock is available, the recommended approach for calculating CRC is to 
use a word clock derived from the bus strobe. The combinational logic is then equivalent to 
shifting sixteen bits serially through the generator polynomial where DOO is shifted in first and 
D15 is shifted in last. 
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Table 26: Equations for parallel generation of an Ultra DMA CRC 


f15 = D14 XOR CRCOUT1 XOR f4 XOR f11 
f16 = D15 XOR CRCOUTO XOR f5 XOR f12 


Notes: 1) f=feedback 
2) D[15:0] = Data to or from the bus 
3) CRCOUT = 16-bit edge triggered result (current CRC) 
4) CRCOUT[15:0] are sent on matching order bits of D[15:00] 


An example of a CRC generator implementation is provided below in Figure 43: Ultra DMA 
Parallel CRC Generator Example. 


: CRCOUT[15:0 


Logic Register Device 


Figure 43: Ultra DMA Parallel CRC Generator Example 
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4.4 Card Configuration 


4.4.1 


4.4.2 


The CompactFlash Storage Cards and CF+ Cards are identified by appropriate information in the 
Card Information Structure (CIS). The following configuration registers are used to coordinate the 
I/O spaces and the Interrupt level of cards that are located in the system. In addition, these 
registers provide a method for accessing status information about the CompactFlash Storage 
Card or CF+ Card that may be used to arbitrate between multiple interrupt sources on the same 
interrupt level or to replace status information that appears on dedicated pins in memory cards 
that have alternate use in I/O cards. 


Single Function CF+ Cards 


Single function CF+ Cards shall have a single configuration tuple describing a single set of 
Function Configuration registers (see the Metaformat Specification). All single function CF+ Card 
configurations are performed using this set of Function Configuration registers. 


Multiple Function CF+ Cards 


Multiple function CF+ Cards shall have a separate set of Configuration registers for each function 
on the card. Multiple Function CF+ Cards shall use a combination of a global CIS common to all 
functions on the card and a separate function-specific CIS specific to each function on the card. 
The global CIS describes features that are common to all functions on the card. A 
CISTPL_LONGLINK_MFC tuple in the global CIS describes the location of a function-specific CIS 
for each function on the CF+ Card. 


NOTE: a CISTPL_FUNCID with a TPLFID_FUNCTION field reset to zero (0) shall not be placed 


in the CIS of a Multiple Function CF+ Card. This tuple is reserved for vendor-specific multiple 
function CF+ Cards that do not follow the multiple function CF+ definitions in the Standard. 


Table 27: CompactFlash Storage Card Registers and Memory Space Decoding 


-ce2]-ce1| Ree |-o awe [ato [Aa [awa [As [aa [ai[Ad] SELECTED SPACE 
SC EE TSE EEE a 


Popa Po pop px fx pm [x pe 
po ft} o fsfotx{x] x |x {x [x] 
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Fo [eonfguaton Rosson Read 
ef ene fees 


x | x_ 
x| x 
x| 0 
x| x_ 
x| x_ 
<2 [eornen ene Wie (8 BOHN) 
x| 0 
x| 0 | 
x{ + | 
x{ 1 | 
Eel 
Aes (ed Atte Wite) 


CF+ & CF SPECIFICATION REV. 3.0 © 1998-2004 COMPACTFLASH ASSOCIATION 


ELECTRICAL INTERFACE 


Table 28: CompactFlash Storage Card Configuration Registers Decoding 


[ee2 [cet [-Res [OF [ve [ato [a0 [as-as [ad [a2 [ai] Ao ELECTED REGTER—_—| 
rx fe fo Pols fot] w [0 [0 [0] 0 |conigaion Onion Reg Read | 
Pac fre fo Pr Po Po fr 0 fo [0 [0] 0 [Contgaton Onion Reg wite | 
Pa fo fo Pops pops | fo fo fil 0 fewest reaserrees 


0 |Card Status pede Write 


Fe OI Et a fc] coc tl [emcee Roce ae 
Pac [re fo Pr Po Po [1 [0 Po [1 [of 0 [Pn Reracoment Reiter wits | 
Pace fro Pot Po [rf «fo [1 [1] [socket and copy ResisiorReed | 
pcre fo Pa Po Po Pr fo Lo [1 [1 Po [socket and copy Resistor wite | 


Table 29: CF+ Card Register and Memory Space Decoding 


(eez[-cei[-nes| oF [we] Aioat [a0 [setecrep space SSSC* 
Defoe [o [0 [+ | 10K [0 foontguaton Regntow Read 
PPro [4 [0 [4 [200 foormen temo Resa @ 8to750) | 
roa [4 [0 [+ [20% | foormon enon Read @ er ore08) | 
Po Po [+] 0+] 10% | 0 [common MemoryRead fe eiois00) | 
Defoe [o [a fo | 0K [0 fooniguatin Reis wie 
PPro [4 [40 [00 focmmen mony wt 6 ator Bo) | 
Poa [4 [4 [0 [0K [common Memon wits 6k ote08) | 
ro Po [+ [1 fo | 0% | 0 [common Memon Wie 6 eto1s00) | 
Px fro [o |e [ + | 10K [0 feartniomaton Siucure ese | 
PPro fo [fo | 0K [0 va oes 18 wits) 
Pa Pre [oo [+ | 0K [1 nats cess (026 Att Rees) | 
PPro fo fa fo [0% [1 vats cess (026 Atrbute wits) | 
raf fo | [+ | 10K fas cess (2e Atrbut eae) | 
rea fo fa fo [0% vas acess (026 Atrbute wits) | 
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Table 30: CF+ Card Configuration Registers Decoding 


-CE2 | -CE1 | -REG | -OE | -WE | A10-A5| A4/ A3 | A2 | A1 | AO | Selected Register 

X 0 0 0 1 XX 0 0 0 0 0 | Configuration Option Reg Read 
0 0 1 0 XX 0 0 0 0 0 | Configuration Option Reg Write 

X 0 0 0 1 XX 0 0 0 1 0 | Card Status Register Read 

Xx 0 0 1 0 XX 0 0 0 1 0 | Card Status Register Write 

X 0 0 0 1 XX 0 0 1 0 O | Pin Replacement Register Read 

X 0 0 1 0 XX 0 0 1 0 O | Pin Replacement Register Write 

X 0 0 0 1 XX 0 0 1 1 0 | Socket and Copy Register Read 

X 0 0 1 0 XX 0 0 1 1 O | Socket and Copy Register Write 

X 0 0 0 1 XX 0 1 0 0 O | Reserved 

X 0 0 1 0 XX 0 1 0 1 0 | I/O Base 0 

X 0 0 0 1 XX 0 1 1 0 O | I/O Base 1 

X 0 0 1 0 XX 0 1 1 1 O | Reserved 

X 0 0 0 1 XX 1 0 0 0 O | Reserved 

X 0 0 1 0 XX 1 0 0 1 O | W/O Limit 

X 0 0) 0 1 XX 1 0 1 0 O | Reserved 
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Note: For CompactFlash Storage Cards, the location of the card configuration registers should always be 
read from the CIS since these locations may vary in future products. For CF+ Cards, the location of 
the card configuration registers shall always be read from the CIS. No writes should be performed to 
the CompactFlash Storage Card or CF+ Card attribute memory except to the card configuration 
register addresses. All other attribute memory locations are reserved. 
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4.4.3 Attribute Memory Function 


Attribute memory is a space where CompactFlash Storage Card and CF+ Card identification and 
configuration information are stored, and is limited to 8 bit wide accesses only at even addresses. 
The card configuration registers are also located here. For CompactFlash Storage Cards, the 
base address of the card configuration registers is 200h. For CF+ cards, the base address of the 
card configuration registers is determined by the Configuration tuple (CISTPL_CONFIG). 


For the Attribute Memory Read function, signals -REG and -OE shall be active and -WE inactive 
during the cycle. As in the Main Memory Read functions, the signals -CE1 and -CE2 control the 
even-byte and odd-byte address, but only the even-byte data is valid during the Attribute Memory 
access. Refer to Table 31: Attribute Memory Function below for signal states and bus validity for 
the Attribute Memory function. 


Table 31: Attribute Memory Function 


Function Mode 
Standby Mode 


Read Byte Access 
CIS ROM (8 bits) 


Write Byte Access 
CIS (8 bits) (Invalid) 


Read Byte Access 
Configuration CompactFlash 
Storage (8 bits) 


Write Byte Access 
Configuration CompactFlash 
Storage (8 bits) 


Read Byte Access 
Configuration CF+ (8 bits) 


Write Byte Access 
Configuration CF+ (8 bits) 


Write Word Access 
CIS (16 bits) (Invalid) 


Read Word Access 
Configuration CompactFlash 
Storage (16 bits) 


Write Word Access 
Configuration CompactFlash 
Storage (16 bits) 


Read Word Access 


E L L 
Configuration CF+ (16 bits) 


Write Word Access 
Configuration CF+ (16 bits) 


Read Word Access L Not Valid | Even Byte 
CIS (16 bits) 
L Don’ 


D15-D8 D7-D0 
High Z High Z 


High Z Even Byte 


High Z Even Byte 


aie 
High Z Even Byte 


Don’t Care | Even Byte 


Not Valid | Even Byte 


_ 
Not Valid | Even Byte 


L Don’t Care | Even Byte 


Note: The -CE signal or both the -OE signal and the -WE signal shall be de-asserted between consecutive 


cycle operations. 
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4.4.4 Configuration Option Register (Base + 00h in Attribute Memory) 
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The Configuration Option Register is used to configure the cards interface, address decoding and 
interrupt and to issue a soft reset to the CompactFlash Storage Card or CF+ Card. 


Operation D7 D6 D5 D4 D3 D2 D1 DO 
R/W SRESET | LeviREQ | Conf5 | Conf4 | Conf3 | Conf2 | Conf1 | ConfO 


Figure 44: Configuration Option Register 


SRESET - Soft Reset: setting this bit to one (1), waiting the minimum reset width time and 
returning to zero (0) places the CompactFlash Storage Card or CF+ Card in the Reset state. 
Setting this bit to one (1) is equivalent to assertion of the +RESET signal except that the 
SRESET bit is not cleared. Returning this bit to zero (0) leaves the CompactFlash Storage 
Card or CF+ Card in the same un-configured, Reset state as following power-up and 
hardware reset. This bit is set to zero (0) by power-up and hardware reset. For CompactFlash 
Storage Cards, using the PCMCIA Soft Reset is considered a hard Reset by the ATA 
Commands. Contrast with Soft Reset in the Device Control Register. 


LevIREQ: this bit is set to one (1) when Level Mode Interrupt is selected, and zero (0) when 
Pulse Mode is selected. Set to zero (0) by Reset. 


Conf5 - Conf0 - Configuration Index: set to zero (0) by reset. It is used to select operation 
mode of the CompactFlash Storage Card or CF+ Card as shown below. 


Note: ConfS and Conf4 are reserved for CompactFlash Storage cards and shall be written as zero (0). 
These bits are vendor defined for CF+ Cards. 


Table 32: CompactFlash Storage Card Configurations 


roe fo fo [oe | 0 | 0 |Menyiome 


1 /O Mapped, Any 16 byte system decoded 
boundary 


po | oo | oo | oO ft | 0 | VOMapped, 1FontF7niareh-sF7h | 
po fo fF oo | oo ft | + vO Mapped, 170n-177h76n-377h | 


Table 33: CF+ Card Configurations 


po | oo | 0 | 0 | oO | 0 | Memory Mapped, VO cycles are ignored | 
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On Multiple Function CF+ Cards, bits in this field enable the following functionality: 


ConfO Enable Function - If this bit is reset to zero (0), the function is disabled. If this bit is set to one 
(1), the function is enabled. 
Conf1 Enable Base and Limit Registers — If this bit is reset to zero (0) and Bit 0 is set to one (1), all 


I/O addresses on the host system are passed to the function. If this bit is set to one (1) and Bit 
0 is set to one (1), then only I/O addresses that are qualified by the Base and Limit registers 
are passed to the function. If Bit 0 is reset to zero (0), this bit is undefined. 


Conf2 Enable -IREQ Routing — If this bit is reset to zero (0) and Bit 0 is set to one (1), this function 
shall not generate interrupt requests on the CF+ Card’s -IREQ line. If this is set to one (1) and 
Bit 0 is set to one (1), this function shall generate interrupt requests on the CF+ Card’s -IREQ 
line. If Bit 0 is reset to zero (0), this bit is undefined. 


Conf[5:3] | Reserved for vendor implementation. 
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4.4.5 Card Configuration and Status Register (Base + 02h in Attribute Memory) 


82 


The Card Configuration and Status Register contains information about the Card’s condition. 


Operation D7 D6 D5 D4 D3 D2 D1 DO 
Read Changed SigChg 1Ois8 -XE Audio PwrDwn Int 0 
Write 0 SigChg lOis8 -XE Audio PwrDwn 0 0 


Figure 45: Card Configuration and Status Register 


Changed: indicates that one or both of the Pin Replacement register CReady, or CWProt bits are 
set to one (1). When the Changed bit is set, -STSCHG Pin 46 is held low if the SigChg bit is a 
One (1) and the CompactFlash Storage Card or CF+ Card is configured for the I/O interface. 


SigChg: this bit is set and reset by the host to enable and disable a state-change “signal” from 
the Status Register, the Changed bit controls pin 46, the Changed Status signal. If no state 
change signal is desired, this bit is set to zero (0) and pin 46 (-STSCHG) signal is then held 
high while the CompactFlash Storage Card or CF+ Card is configured for I/O. 


IOis8: the host sets this bit to a one (1) if the CompactFlash Storage Card or CF+ Card is to be 
configured in an 8 bit I/O Mode. The CompactFlash Storage Card is always configured for 
both 8 and 16 bit I/O, so this bit is ignored. Some CF+ cards can be configured for either 8 bit 
I/O mode or 16 bit I/O mode, so CF+ cards may respond to this bit. 


-XE: this bit is set and reset by the host to disable and enable Power Level 1 commands in CF+ 
cards. If the value is 0, Power Level 1 commands are enabled; if it is 1, Power Level 1 
commands are disabled. Default value at power on or after reset is 0. The host may read the 
value of this bit to determine whether Power Level 1 commands are currently enabled. For 
CompactFlash cards that do not support Power Level 1, this bit has value O and is not 
writeable. 


Audio: this bit is set and reset by the host to enable and disable audio information on -SPKR 
when the CF+ card is configured. This bit should always be zero for CompactFlash Storage 
cards. 


PwrDwn: this bit indicates whether the host requests the CompactFlash Storage Card or CF+ 
Card to be in the power saving or active mode. When the bit is one (1), the CompactFlash 
Storage Card or CF+ Card enters a power down mode. When PwrDwn is zero (0), the host is 
requesting the CompactFlash Storage Card or CF+ Card to enter the active mode. The 
PCMCIA READY value becomes false (busy) when this bit is changed. READY shall not 
become true (ready) until the power state requested has been entered. The CompactFlash 
Storage Card automatically powers down when it is idle and powers back up when it receives 
a command. 


Int: this bit represents the internal state of the interrupt request. This value is available whether or 
not the I/O interface has been configured. This signal remains true until the condition that 
caused the interrupt request has been serviced. If interrupts are disabled by the -IEN bit in 
the Device Control Register, this bit is a zero (0). 
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4.4.6 Pin Replacement Register (Base + 04h in Attribute Memory) 


Operation D7 D6 D5 D4 D3 D2 D1 DO 
Read 0 0 CReady CWProt 1 1 RReady WProt 
Write 0 0 CReady CWProt 0 0 MReady MWProt 


Figure 46: Pin Replacement Register 


CReady: this bit is set to one (1) when the bit RReady changes state. This bit can also be written 


by the host. 


CWProt: this bit is set to one (1) when the RWprot changes state. This bit may also be written by 


the host. 


RReady: this bit is used to determine the internal state of the READY signal. This bit may be 
used to determine the state of the READY signal as this pin has been reallocated for use as 
Interrupt Request on an I/O card. When written, this bit acts as a mask (MReady) for writing 
the corresponding bit CReady. 


WProt: this bit is always zero (0) since the CompactFlash Storage Card or CF+ Card does not 
have a Write Protect switch. When written, this bit acts as a mask for writing the 
corresponding bit CWProt. 


MReady: this bit acts as a mask for writing the corresponding bit CReady. 


MWProt: this bit when written acts as a mask for writing the corresponding bit CWProt. 


Table 34: Pin Replacement Changed Bit/Mask Bit Values 


Initial Value Written by Host Final Comments 
of (C) Status “C” Bit “M” Bit “C” Bit 
0 Xx 0 0 Unchanged 
1 Xx 0 1 Unchanged 
Xx 0 1 0 Cleared by Host 
xX 1 1 1 Set by Host 
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4.4.7 Socket and Copy Register (Base + 06h in Attribute Memory) 


4.4.8 
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This register contains additional configuration information. This register is always written by the 
system before writing the card’s Configuration Index Register. This register is not required for CF 
or CF+ Cards. 


If present, it is optional for a CF Card to allow setting bit D4 (Drive number) to 1. If two drives are 
supported, it is intended for use only when two cards are co-located at either the primary or 
secondary addresses in PCMCIA I/O mode. The availability and capabilities of this register are 
described in the Card Information Structure of the CF Card. 


Hosts shall not depend on the availability of this functionality. 


Operation D7 D6 D5 D4 D3 D2 D1 DO 

Read Reserved 0 0 Obsolete’ 0 0) 0 0 
(Drive #) 

Write 0 0 0 Obsolete’ 4 x x x 
(Drive #) 


Figure 47: Socket and Copy Register 


Reserved: this bit is reserved for future standardization. This bit shall be set to zero (0) by the 
software when the register is written. 


Obsolete (Drive #): this bit is obsolete and should be written as 0. 


If the obsolete functionality is not supported it shall be read as written or shall be read as O. If 
the obsolete functionality is supported, the bit shall be read as written. If supported, this bit 
sets the drive number, which the card matches with the DRV bit of the Drive/Head register 
when configured in a twin card configuration. 


It is recommended that the host always write O for the drive number in this register and in the 
DRV bit of the Drive/Head register for PCMCIA modes of operation. 


X: the socket number is ignored by the CompactFlash Storage Card. 


I/O Base Register (0, 1) 


The I/O Base registers are optional on single function CF+ Cards and are required on multiple 
function CF+ Cards. The I/O Base registers determine the base address of the I/O range used to 
access function-specific registers on the CF+ Card. These registers allow the CF+ Card’s 
function-specific registers to be placed anywhere in the host system’s I/O address space. The 
registers are written in little-endian order with the least significant byte of the base I/O address 
written to I/O Base 0. 


The number of I/O Base Address registers implemented depends on the number of address lines 
the CF+ Card decodes. For example, if the function on the CF+ Card only decodes eight (8) 
address lines, only the first register needs to be implemented. 
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Offset D7 D6 D5 D4 D3 D2 D1 DO 
10 1/O Base 0 
12 1/O Base 1 


Figure 48: I/O Base Registers (0, 1) 
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4.4.9 I/O Limit Register 
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The I/O Limit register is an optional register and is only implemented on CF+ Cards that use I/O 
Base Address registers. If the function on the CF+ Card always uses the same number of I/O 
registers in all configurations, this register may be omitted (even on CF+ Cards with I/O Base 
Address registers). 


This register specifies the number of address lines used by the function. Each bit in the register 
represents an I/O address line. This allows two (2) to two hundred and fifty-six (256) I/O ports to 
be used by a function. If a bit in the register is set to one (1), all bits of lesser significance in the 
register shall also be set to one (1). 


Offset D7 D6 D5 D4 D3 D2 D1 DO 
18 W/O Limit 
Field Type Description 
VO Limit R/W Bit-mapped register indicating the number of I/O address lines decoded by the 


function on the CF+ Card. 


Figure 49: I/O Limit Register 
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4.5 W/O Transfer Function 


4.5.1 I/O Function 


The I/O transfer to or from the CompactFlash Storage or CF+ Card can be either 8 or 16 bits. 
When a 16 bit accessible port is addressed, the signal -IOIS16 is asserted by the CompactFlash 
Storage or CF+ Card. Otherwise, the -lIOIS16 signal is de-asserted. When a 16 bit transfer is 
attempted, and the -IOIS16 signal is not asserted by the CompactFlash Storage or CF+ Card, the 
system shall generate a pair of 8 bit references to access the word‘s even byte and odd byte. The 
CompactFlash Storage Card permits both 8 and 16 bit accesses to all of its I/O addresses, so 
-IOIS16 is asserted for all addresses to which the CompactFlash Storage responds. CF+ cards 
may or may not allow 16 bit register accesses and thus shall assert -IOIS16 as required. 


The CompactFlash Storage and CF+ Card may request the host to extend the length of an input 
cycle until data is ready by asserting the -WAIT signal at the start of the cycle. 


Table 35: PCMCIA Mode I/O Function 


Don’t Care Even-Byte 
Don’t Care Odd-Byte 


I/O Read Inhibit X L 
/O Write Inhibit H X H High Z 


High Byte Input Only L H L H Odd-Byte 

(8 bits) 

High Byte Output Only L L H Xx H L Odd-Byte Don’t Care 
(8 bits) 
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4.6 Common Memory Transfer Function 


4.6.1 Common Memory Function 


The Common Memory transfer to or from the CompactFlash Storage or CF+ Card can be either 8 
or 16 bits. 


The CompactFlash Storage Card and the CF+ Card permit both 8 and 16 bit accesses to all of its 
Common Memory addresses. 


The CompactFlash Storage Card or the CF+ Card may request the host to extend the length of a 
memory write cycle or extend the length of a memory read cycle until data is ready by asserting 
the -WAIT signal at the start of the cycle. 


Table 36: Common Memory Function 


Standby Mode High Z 


L H High Z Even-Byte 

L H High Z Odd-Byte 

L Don’t Care Even-Byte 

L Don’t Care Odd-Byte 

Odd-Byte Even-Byte 
Odd-Byte Even-Byte 


= 
>| 
» 


Byte Read Access 
(8 bits) 


a 2 
TT 


Byte Write Access 
(8 bits) 


Word Read Access 
(16 bits) 


Word Write Access 
(16 bits) 


Odd Byte Read Only 
(8 bits) 


Odd Byte Write Only 
(8 bits) 


| ree a 
x= rr 
LL 


H Odd-Byte High Z 
L Odd-Byte Don’t Care 


H H 
H H 
H H 
H H 


88 CF+ & CF SPECIFICATION REV. 3.0 © 1998-2004 COMPACTFLASH ASSOCIATION 


ELECTRICAL INTERFACE 


4.7 True IDE Mode I/O Transfer Function 


4.7.1 True IDE Mode I/O Function 


The CompactFlash Storage Card and CF+ Card can be configured in a True IDE Mode of 
operation. The CompactFlash Storage Card is configured in this mode only when the -OE input 
signal is grounded by the host during the power off to power on cycle. Optionally, CompactFlash 
Storage Cards and CF+ Cards may support the following optional detection methods: 


1. The card is permitted to monitor the -OE (-ATA SEL) signal at any time(s) and switch to 
PCMCIA mode upon detecting a high level on the pin. 


2. The card is permitted to re-arbitrate the interface mode determination following a transition of 
the (-)RESET pin. 


3. The card is permitted to monitor the -OE (-ATA SEL) signal at any time(s) and switch to True 
IDE mode upon detection of a continuous low level on pin for an extended period of time. 


Host implementers should not rely on any of these optional detection methods in their designs. In 
the True IDE Mode, the PCMCIA protocol and configuration are disabled and only I/O operations 
to the Task File and Data Register are allowed. In this mode, no Memory or Attribute Registers 
are accessible to the host. CompactFlash Storage Cards permit 8 bit PIO mode data accesses if 
the user issues a Set Feature Command to put the CompactFlash Storage Card in 8 bit Mode. 


Note: Removing and reinserting the CompactFlash Storage Card while the host computer’s power is on will 
reconfigure the CompactFlash Storage Card to PC Card ATA mode from the original True IDE Mode. 
To configure the CompactFlash Storage Card in True IDE Mode, the 50-pin socket is power cycled 
with the CompactFlash Storage Card inserted and -OE (output enable) asserted. 


CF+ Card support of True IDE mode is optional. 
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Table 37: True IDE Mode I/O Function defines the function of the operations for the True IDE 
Mode. 


Table 37: True IDE Mode I/O Function 


-CS D7-D0 


Undefined | Undefined 
In/Out In/Out 


Function Code 


r 


Invalid Modes 


Undefined 
Out 


Undefined 


Undefined 
Out 


Undefined 


Standby Mode 
Task File Write Don’t Care Data In 
High Z Data Out 


Odd-Byte | Even-Byte 
In 


Odd-Byte | Even-Byte 
In 


Odd-Byte | Even-Byte 
In 


H L H Odd-Byte | Even-Byte 
Out Out 


Task File Read 


PIO Data 
Register Write 


DMA Data 
Register Write 


Ultra DMA Data 
Register Write 


PIO Data 
Register Read 


DMA Data 
Register Read 


Ultra DMA Data 
Register Read 


= 


Out Out 


Odd-Byte | Even-Byte 
Out Out 


Control Register Don’t Care | Control In 


Write 


Alt Status Read Status Out 


Drive Address’ Data Out 
Notes:1) Implemented for backward compatibility. Bit D7 of the register shall remain High Z to prevent 
conflict with any floppy disk controller at the same address. The host software should not rely on the 
contents of this register. 


r 


Ea 
er 
straws [A 
tienes [Ho 
Eee 
Eee 
Ec 
Pismarnoos | 
PaseReoe | 
Eee 
aust [L 
rast | 


2) In Ultra DMA Data Register Write mode the signals -IORD, -IOWR and IORDY are redefined and 
used as follows: -IORD as HSTROBE, —IOWR as STOP and IORDY as -DDMARDY. Data transfers 
with each edge of HSTROBE. See Section 4.3.18: True IDE Ultra DMA Mode Read/Write Timing 
Specification and Table 5: Signal Description for complete information. 


3) In Ultra DMA Data Register Read mode the signals -IORD, —IOWR and IORDY are redefined and used as follows: 
—IORD as -HDMARDY H, -IOWR as STOP and IORDY as DSTROBE. Data transfers with each edge of DSTROBE. 
See Section 4.3.18: True IDE Ultra DMA Mode Read/Write Timing Specification and Table 5: Signal Description for 
complete information. 
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4.8 Host Configuration Requirements for Master/Slave or New Timing Modes 


The CF Advanced Timing modes include PCMCIA style I/O modes that are faster than the original 250 ns 
cycle time. These modes are not supported by the PCMCIA specification nor CF by cards based on 
revisions of the CF specification before Revision 3.0. Hosts shall ensure that all cards accessed through a 
common electrical interface are capable of operation at the desired, faster than 250 ns, I/O mode before 
configuring the interface for that I/O mode. 


Advanced Timing modes are PCMCIA style I/O modes that are 100 ns or faster, PCMCIA Memory modes 
that are 100ns or faster, True IDE PIO Modes 5,6 and Multiword DMA Modes 3,4. These modes are 
permitted to be used only when a single card is present and the host and card are connected directly, 
without a cable exceeding 0.15m in length. Consequently, the host shall not configure a card into an 
Advanced Timing Mode if two cards are sharing I/O lines, as in Master/Slave operation, nor if it is 
constructed such that a cable exceeding 0.15 meters is required to connect the host to the card. 


The load presented to the Host by cards supporting Ultra DMA is more controlled than that presented by 
other CompactFlash cards. Therefore, the use of a card that does not support Ultra DMA in a Master/Slave 
arrangement with a Ultra DMA card can affect the critical timing of the Ultra DMA transfers. The host shall 
not configure a card into Ultra DMA mode when a card not supporting Ultra DMA is also present on the 
same interface 


When the use of two cards on an interface is otherwise permitted, the host may use any mode that is 


supported by both cards, but to achieve maximum performance it should use its highest performance mode 
that is also supported by both cards. 
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5.1 


5 Metaformat 


Metaformat Overview 


The goal of the Metaformat is to describe the requirements and capabilities of the CompactFlash 
Storage Card and CF+ Card as thoroughly as possible. This includes describing the power 
requirements, IO requirements, memory requirements, manufacturer information and details 
about the services provided. 


The Metaformat is a hierarchy of layers. Each layer is numbered with a number that increases as 
the level of abstraction gets higher. Included are layers to describe the data recording format and 
data organization, for memory and ATA cards that wish to adhere to the CFA/PCMCIA 
specification. Below the Metaformat is the physical layer, the electrical and physical 
characteristics of CF+ Cards. The CF+ Metaformat conforms directly to the PCMCIA Metaformat 
Specification. Refer to that document for a detailed description of the Metaformat. 


5.2 Metaformat Requirements 


The CF+ Cards have the following Card Information Structure (CIS) requirements: 


« All CF+ Cards have a CIS that describes the functionality and characteristics of the card 


= The CIS of a CF+ Card shall be readable whenever the card is powered, the card is asserting 
READY and the card has been reset by the host after power-up in accordance with the 
CompactFlash Standard. This includes after the CF+ Card is configured and when the 
PwrDwn bit is set in the Card Configuration and Status Register. (See the Electrical 
Specification, section 4.) 


= All CF+ Cards shall provide at least the mandatory Tuples as described in the PCMCIA 
Metaformat Specification, Tuple Summary Table. 


« All linear memory CF+ Cards shall describe how they are partitioned, even if the entire CF+ 
Card is used as a single partition. 


5.2.1 Metaformat Representation for Extended Speed Modes 


92 


The PCMCIA Device Info Tuple is used to express operating speed of Compact Flash memory 
mapped registers. The cycle times defined in this specification are: 250, 120, 100 and 80 
nanoseconds. These cycle times can be expressed as described in Table 38 below. See the 
PCMCIA Metaformat, Guidelines and PC Card-ATA specifications for further information on the 
methods of expressing speed and other information about the capabilities of the card. 


Legend for Table 38: Sample Device Info Tuple Information for Extended Speeds 


Attribute | Code Notes 
Memory 
Relative 

Offset 


Offset Device Type Speed Code ieee 

N+0 (7=Extended) ieee 

Legend Offset Extend| Extended Speed Mantissa | Extended Speed Present if 
N+2 Exponent Speed 

Code = 7 
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Table 38: Sample Device Info Tuple Information for Extended Speeds 


Attribute | Code Notes 
Memory 
Relative 

Offset 


Eel leat Dh = Function Specific (al 1h = 250 nsec eee | 
eee | 


eat Dh = Function Specific ai 7h = Extended CFA 

Defined 

rape fae Dh = Function Specific ml 4h = 100 nsec PCMCIA 
Dh = Function Specific 4 | 7h = Extended CFA 

Defined 


Note: The value “1” defined for D3 of the N+0 words indicates that no write-protect switch controls writing 
the ATA registers. The value “0” defined for D7 in the N+2 words indicates that there is not more than 
a single speed extension byte. 


Alert! 


The parameter values for the cycle times in the tuples above do not have detailed timings 
defined by PCMCIA for other than 100 and 250 nsec. Therefore, there may be ambiguity on 
the part of a PCMCIA host system in applying the alternate values correctly. 


At present, there is no standard method of describing Extended Speed I/O timings in the 
Card Information Structure. 
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6 Software Interface 


6.1 CF-ATA Drive Register Set Definition and Protocol 
The CompactFlash Storage Card can be configured as a high performance I/O device through: 


a) The standard PC-AT disk I/O address spaces 1FOh-1F7h, 3F6h-3F7h (primary) or 170h- 
177h, 376h-377h (secondary) with IRQ 14 (or other available IRQ). 


b) Any system decoded 16 byte I/O block using any available IRQ. 

c) Memory space. 

The communication to or from the CompactFlash Storage Card is done using the Task File 
registers, which provide all the necessary registers for control and status information related to 


the storage medium. The PCMCIA interface connects peripherals to the host using four register 
mapping methods. Table 39 is a detailed description of these methods: 


Table 39: I/O Configurations 


Standard Configurations 


Note: Twin Card implementation is obsolete. Refer to Section 4.4.7: Socket and Copy Register (Base + 06h 
in Attribute Memory)for Twin Card implementation. 


94 CF+ & CF SPECIFICATION REV. 3.0 © 1998-2004 COMPACTFLASH ASSOCIATION 


6.1.1 


SOFTWARE INTERFACE 


1/O Primary and Secondary Address Configurations 


Table 40: Primary and Secondary I/O Decoding 


ree [avae [as [a2 [at [a0 [ono [iownco [Now 
To [artim [0 [oo [0 [evennobae  [eenwnbaa [12 
To Partin [oo fo [1 | eworregiter | reawres [1.2 
To Partin Po Loft [0 | secorcaunt  [Secercout | 
To farce Po Loft 1 [secon [secerne. | 


To [arcane Lo [+ [0 | © [oyindertow [ovindertow | 
To faranm [o [+ Po | 4 Poyindernigh [vinderrgh | 
To [arcinm [0 [+ [1 | 0 [selec caratiocd [selec carancaa | 
To foram Loft [1 [+ [seus [commend | 
To [arene fo + [1 [0 [arsine [Device conser | 
Po Parone [ot [1 [4 [owendeiecs [Resened | 


Note: 1) Register 0 is accessed with -CE1 low and -CE2 low (and AO = Don't Care) as a word register on 
the combined Odd Data Bus and Even Data Bus (D15-D0). This register may also be accessed by a 
pair of byte accesses to the offset 0 with -CE1 low and -CE2 high. Note that the address space of this 
word register overlaps the address space of the Error and Feature byte-wide registers, which lie at 
offset 1. When accessed twice as byte register with -CE1 low, the first byte to be accessed is the 
even byte of the word and the second byte accessed is the odd byte of the equivalent word access. 


2) A byte access to register 0 with -CE1 high and -CE2 low accesses the error (read) or feature 
(write) register. 
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6.1.2 Contiguous I/O Mapped Addressing 


When the system decodes a contiguous block of I/O registers to select the CompactFlash 
Storage Card, the registers are accessed in the block of I/O space decoded by the system as 
follows: 


Table 41: Contiguous I/O Decoding 


cres [as [m2 [mi [a0 [ones | sonoco[sownco | Nowe | 
ro fofolo[o| o | tenmooaa | cienwnoae | i _| 


Notes: 1) Register 0 is accessed with -CE1 low and -CE2 low (and AO = Don’t Care) as a word register on 
the combined Odd Data Bus and Even Data Bus (D15-D0). This register may also be accessed by a 
pair of byte accesses to the offset 0 with -CE1 low and -CE2 high. Note that the address space of this 
word register overlaps the address space of the Error and Feature byte-wide registers that lie at offset 
1. When accessed twice as byte register with -CE1 low, the first byte to be accessed is the even byte 
of the word and the second byte accessed is the odd byte of the equivalent word access. 


A byte access to register 0 with -CE1 high and -CE2 low accesses the error (read) or feature (write) 
register. 


2) Registers at offset 8, 9 and D are non-overlapping duplicates of the registers at offset 0 and 1. 


Register 8 is equivalent to register 0, while register 9 accesses the odd byte. Therefore, if the 
registers are byte accessed in the order 9 then 8 the data shall be transferred odd byte then even 
byte. 


Repeated byte accesses to register 8 or 0 shall access consecutive (even than odd) bytes from the 
data buffer. Repeated word accesses to register 8, 9 or 0 shall access consecutive words from the 
data buffer. Repeated byte accesses to register 9 are not supported. However, repeated alternating 
byte accesses to registers 8 then 9 shall access consecutive (even then odd) bytes from the data 
buffer. Byte accesses to register 9 access only the odd byte of the data. 


3) Address lines that are not indicated are ignored by the CompactFlash Storage Card for accessing 
all the registers in this table. 
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6.1.3 Memory Mapped Addressing 
When the CompactFlash Storage Card registers are accessed via memory references, the 
registers appear in the common memory space window: 0-2K bytes as follows: 


Table 42: Memory Mapped Decoding 


fees [Ao] aaa [as [a2] ai [A0[orset] oso [WE [Notes 
Se 
Ss 
fe Popes [of 2 | seercan | Secercaun 
Pe fete fof | ennirtow [Onision 
fs 
Pio [x for] [ole | saeco nies | Soest Coareee | 
ns 
es 
rife Ps foe [|e |e. oss bas | ou. osawebas |? 
fet fe fs fe | oimeror | n.reoues |? 
fete fof [asus [tev 
fs 
i 9 
i PT Dc Fe [sso cae | osswe ove [3 


Notes: 1) Register 0 is accessed with -CE1 low and -CE2 low as a word register on the combined Odd Data 
Bus and Even Data Bus (D15-D0). This register may also be accessed by a pair of byte accesses to 
the offset 0 with -CE1 low and -CE2 high. Note that the address space of this word register overlaps 
the address space of the Error and Feature byte-wide registers that lie at offset 1. When accessed 
twice as byte register with -CE1 low, the first byte to be accessed is the even byte of the word and the 
second byte accessed is the odd byte of the equivalent word access. 


A byte access to address 0 with -CE1 high and -CE2 low accesses the error (read) or feature (write) 
register. 


2) Registers at offset 8, 9 and D are non-overlapping duplicates of the registers at offset 0 and 1. 


Register 8 is equivalent to register 0, while register 9 accesses the odd byte. Therefore, if the 
registers are byte accessed in the order 9 then 8 the data shall be transferred odd byte then even 
byte. 


Repeated byte accesses to register 8 or 0 shall access consecutive (even then odd) bytes from the 
data buffer. Repeated word accesses to register 8, 9 or 0 shall access consecutive words from the 
data buffer. Repeated byte accesses to register 9 are not supported. However, repeated alternating 
byte accesses to registers 8 then 9 shall access consecutive (even then odd) bytes from the data 
buffer. Byte accesses to register 9 access only the odd byte of the data. 


3) Accesses to even addresses between 400h and 7FFh access register 8. Accesses to odd 
addresses between 400h and 7FFh access register 9. This 1 Kbyte memory window to the data 
register is provided so that hosts can perform memory to memory block moves to the data register 
when the register lies in memory space. 
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6.1.4 


6.1.5 
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Some hosts, such as the X86 processors, must increment both the source and destination addresses 
when executing the memory to memory block move instruction. Some PCMCIA socket adapters also 
have auto incrementing address logic embedded within them. This address window allows these 
hosts and adapters to function efficiently. 


Note that this entire window accesses the Data Register FIFO and does not allow random access to 
the data buffer within the CompactFlash Storage Card. 


A word access to address at offset 8 shall provide even data on the low-order byte of the data bus, 
along with odd data at offset 9 on the high-order byte of the data bus. 


True IDE Mode Addressing 


When the CompactFlash Storage Card or CF+ Card is configured in the True IDE Mode, the I/O 
decoding is as follows: 


Table 43: True IDE Mode I/O Decoding 


[esi [050 | a2 [ai | An [-owack [sono -[aowrs0 [Note | 


Popa ft [1 sectorno. | sectorNo. | 
Po fe [+ [oyindertow | eyindortow | 
Po ft [+ [oyinder igh | eyindorrigh | 
Ti fo [+ select Carsticad | Select Cerioad | 
rife [4 asians [Device contrat | 


Note: 1) See the section 6.1.5 CF-ATA Registers for information regarding the control of 8 or 16 bit 
transfers to the data register. 


CF-ATA Registers 


The following section describes the hardware registers used by the host software to issue 
commands to the CompactFlash device. These registers are often collectively referred to as the 
“task file.” 


Note: In accordance with the PCMCIA specification: each of the registers below that is located at an odd 
offset address may be accessed in the PC Card Memory or PC Card I/O modes at its normal address 
and also the corresponding even address (normal address -1) using data bus lines (D15-D8) when 
-CE1 is high and -CE2 is low unless -IOIS16 is high (not asserted by the card) and an I/O cycle is 
being performed. 


In the True IDE mode of operation, the size of the transfer is based solely on the register being 
addressed. All registers are 8 bit only except for the Data Register, which is normally 16 bits, but can 
be programmed to use 8 bit transfers for Non-DMA operations through the use of the Set Features 
command. The data register is also 8 bits during a portion of the Read Long and Write Long 
commands, which exist solely for historical reasons and should not be used. 
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6.1.5.1 Data Register (Address - 1F0h[170h]; Offset 0,8,9) 


The Data Register is a 16 bit register, and it is used to transfer data blocks between the 
CompactFlash Storage Card data buffer and the Host. This register overlaps the Error Register. 
Table 44: Data Register Access below describes the combinations of data register access and is 
provided to assist in understanding the overlapped Data Register and Error/Feature Register 
rather than to attempt to define general PCMCIA word and byte access modes and operations. 
See the PCMCIA PC Card Standard, for further definitions of the Card Accessing Modes for I/O 
and Memory cycles. 


Note: Because of the overlapped registers, PC Card modes access to the 1F1h, 171h or offset 1 are not 
defined for word (-CE2 = 0 and -CE1 = 0) operations. These accesses are treated as accesses to the 
Word Data Register. The duplicated registers at offsets 8, 9 and Dh have no restrictions on the 
operations that can be performed by the socket. 


Table 44: Data Register Access 


D15-D0 
D7-D0O 
D7-DO 

D15-D8 
D7-D0O 


D15-D8 


D15-D8 
Data Bus 


D15-D0 
D15-D0 


PIO Byte Data Register D7-D0O 
(Selected Using Set 
Features Command) 


Notes: 1) -REG signal is mode dependent. Signal shall be 0 for I/O mode and 1 for Memory Mode. 
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Error Register (Address - 1F1h[171h]; Offset 1, ODh Read Only) 


This register contains additional information about the source of an error when an error is 
indicated in bit 0 of the Status register. The bits are defined as follows: 


D7 D6 D5 D4 D3 D2 D1 DO 
BBK/ICRC UNC 0 IDNF 0 ABRT 0 AMNF 


Figure 50: Error Register 


This register is also accessed in PC Card Modes on data bits D15-D8 during a read operation to 
offset 0 with -CE2 low and -CE1 high. 


Bit 7 (BBK/ICRC): this bit is set when a Bad Block is detected. This bit is also set when an 
interface CRC error is detected in True IDE Ultra DMA modes of operation. 


Bit 6 (UNC): this bit is set wnen an Uncorrectable Error is encountered. 
Bit 5: this bit is 0. 

Bit 4 (IDNF): the requested sector ID is in error or cannot be found. 

Bit 3: this bit is 0. 


Bit 2 (Abort) This bit is set if the command has been aborted because of a CompactFlash 
Storage Card status condition: (Not Ready, Write Fault, etc.) or when an invalid command 
has been issued. 


Bit1 This bit is 0. 
Bit 0 (AMNF) This bit is set in case of a general error. 


6.1.5.2 Feature Register (Address - 1F1h[171h]; Offset 1, 0Dh Write Only) 


This register provides information regarding features of the CompactFlash Storage Card that the 
host can utilize. This register is also accessed in PC Card modes on data bits D15-D8 during a 
write operation to Offset 0 with -CE2 low and -CE1 high. 


6.1.5.3 Sector Count Register (Address - 1F2h[172h]; Offset 2) 


This register contains the numbers of sectors of data requested to be transferred on a read or 
write operation between the host and the CompactFlash Storage Card. If the value in this register 
is zero, a count of 256 sectors is specified. If the command was successful, this register is zero at 
command completion. If not successfully completed, the register contains the number of sectors 
that need to be transferred in order to complete the request. 


6.1.5.4 Sector Number (LBA 7-0) Register (Address - 1F3h[173h]; Offset 3) 


This register contains the starting sector number or bits 7-0 of the Logical Block Address (LBA) 
for any CompactFlash Storage Card data access for the subsequent command. 


6.1.5.5 Cylinder Low (LBA 15-8) Register (Address - 1F4h[174h]; Offset 4) 


This register contains the low order 8 bits of the starting cylinder address or bits 15-8 of the 
Logical Block Address. 
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6.1.5.6 Cylinder High (LBA 23-16) Register (Address - 1F5h[175h]; Offset 5) 


This register contains the high order bits of the starting cylinder address or bits 23-16 of the 
Logical Block Address. 


6.1.5.7 Drive/Head (LBA 27-24) Register (Address 1F6h[176h]; Offset 6) 


The Drive/Head register is used to select the drive and head. It is also used to select LBA 
addressing instead of cylinder/head/sector addressing. The bits are defined as follows: 


D7 D6 D5 D4 D3 D2 D1 DO 
1 LBA 1 DRV HS3 HS2 HS1 HSO 


Figure 51: Drive/Head Register 


Bit 7: this bit is specified as 1 for backward compatibility reasons. It is intended that this bit will 
become obsolete in a future revision of the specification. This bit is ignored by some 
controllers in some commands. 


Bit 6: LBA is a flag to select either Cylinder/Head/Sector (CHS) or Logical Block Address Mode 
(LBA). When LBA=0, Cylinder/Head/Sector mode is selected. When LBA=1, Logical Block 
Address is selected. In Logical Block Mode, the Logical Block Address is interpreted as 
follows: 


LBA7-LBAO: Sector Number Register D7-DO. 
LBA15-LBA8: Cylinder Low Register D7-D0O. 
LBA23-LBA16: Cylinder High Register D7-DO. 
LBA27-LBA24: Drive/Head Register bits HS3-HSO. 

Bit 5: this bit is specified as 1 for backward compatibility reasons. It is intended that this bit will 
become obsolete in a future revisions of the specification. This bit is ignored by some 
controllers in some commands. 

Bit 4 (DRV): DRV is the drive number. When DRV=0, drive (card) 0 is selected. When DRV=1, 
drive (card) 1 is selected. Setting this bit to 1 is obsolete in PCMCIA modes of operation. If 
the obsolete functionality is support by a CF Storage Card, the CompactFlash Storage Card 
is set to be Card 0 or 1 using the copy field (Drive #) of the PCMCIA Socket & Copy 


configuration register. 


Bit 3 (HS3): when operating in the Cylinder, Head, Sector mode, this is bit 3 of the head number. 
It is Bit 27 in the Logical Block Address mode. 


Bit 2 (HS2): when operating in the Cylinder, Head, Sector mode, this is bit 2 of the head number. 
It is Bit 26 in the Logical Block Address mode. 


Bit 1 (HS1): when operating in the Cylinder, Head, Sector mode, this is bit 1 of the head number. 
It is Bit 25 in the Logical Block Address mode. 


Bit 0 (HSO): when operating in the Cylinder, Head, Sector mode, this is bit O of the head number. 
It is Bit 24 in the Logical Block Address mode. 
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6.1.5.8 Status & Alternate Status Registers (Address 1F7h[177h]&3F6h[376h]; Offsets 7 & 
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Eh) 


These registers return the CompactFlash Storage Card status when read by the host. Reading 
the Status register does clear a pending interrupt while reading the Auxiliary Status register does 
not. The status bits are described as follows: 


D7 D6 D5 D4 D3 D2 D1 DO 


BUSY | RDY | DWF DSC DRQ CORR 0 ERR 


Figure 52: Status & Alternate Status Register 


Bit 7 (BUSY): the busy bit is set when the CompactFlash Storage Card has access to the 
command buffer and registers and the host is locked out from accessing the command 
register and buffer. No other bits in this register are valid when this bit is set to a 1. 


During the data transfer of DMA commands, the Card shall not assert DMARQ unless either 
the BUSY bit, the DRQ bit, or both are set to one. 


Bit 6 (RDY): RDY indicates whether the device is capable of performing CompactFlash Storage 
Card operations. This bit is cleared at power up and remains cleared until the CompactFlash 
Storage Card is ready to accept a command. 

Bit 5 (DWF): This bit, if set, indicates a write fault has occurred. 

Bit 4 (DSC): This bit is set when the CompactFlash Storage Card is ready. 


Bit 3 (DRQ): The Data Request is set when the CompactFlash Storage Card requires that 
information be transferred either to or from the host through the Data register. 


During the data transfer of DMA commands, the Card shall not assert DMARQ unless either 
the BUSY bit, the DRQ bit, or both are set to one. 


Bit 2 (CORR): This bit is set when a Correctable data error has been encountered and the data 
has been corrected. This condition does not terminate a multi-sector read operation. 


Bit 1 (IDX): This bit is always set to 0. 


Bit 0 (ERR): This bit is set when the previous command has ended in some type of error. The bits 
in the Error register contain additional information describing the error. It is recommended 
that media access commands (such as Read Sectors and Write Sectors) that end with an 
error condition should have the address of the first sector in error in the command block 
registers. 
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6.1.5.9 Device Control Register (Address - 3F6h[376h]; Offset Eh) 


This register is used to control the CompactFlash Storage Card interrupt request and to issue an 
ATA soft reset to the card. This register can be written even if the device is BUSY. The bits are 
defined as follows: 


D7 D6 D5 D4 D3 D2 D1 DO 
X(0) X(0) X(0) X(0) X(0) SW Rst -IEn 0 


Figure 53: Device Control Register 


Bit 7: this bit is ignored by the CompactFlash Storage Card. The host software should set this bit 
to 0. 


Bit 6: this bit is ignored by the CompactFlash Storage Card. The host software should set this bit 
to 0. 


Bit 5: this bit is ignored by the CompactFlash Storage Card. The host software should set this bit 
to 0. 


Bit 4: this bit is ignored by the CompactFlash Storage Card. The host software should set this bit 
to 0. 


Bit 3: this bit is ignored by the CompactFlash Storage Card. The host software should set this bit 
to 0. 


Bit 2 (SW Rst): this bit is set to 1 in order to force the CompactFlash Storage Card to perform an 
AT Disk controller Soft Reset operation. This does not change the PCMCIA Card 
Configuration Registers (see Section 4.4.4 to 4.4.9) as a hardware Reset does. The Card 
remains in Reset until this bit is reset to ‘0.’ 


Bit 1 (-IEn): the Interrupt Enable bit enables interrupts when the bit is 0. When the bit is 1, 
interrupts from the CompactFlash Storage Card are disabled. This bit also controls the Int bit 
in the Configuration and Status Register. This bit is set to 0 at power on and Reset. 


Bit 0: this bit is ignored by the CompactFlash Storage Card. 
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6.1.5.10 Card (Drive) Address Register (Address 3F7h[377h]; Offset Fh) 
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This register is provided for compatibility with the AT disk drive interface. It is recommended that 
this register not be mapped into the host’s I/O space because of potential conflicts on Bit 7. The 
bits are defined as follows: 


D7 D6 D5 D4 D3 D2 D1 DO 


X -WTG -HS3 -HS2 -HS1 -HSO -nDS1 -nDSO 


Figure 54: Card (Drive) Address Register 


Bit 7: this bit is unknown. 
Implementation Note: 
Conflicts may occur on the host data bus when this bit is provided by a Floppy Disk Controller 
operating at the same addresses as the CompactFlash Storage Card. Following are some 
possible solutions to this problem for the PCMCIA implementation: 
1) Locate the CompactFlash Storage Card at a non-conflicting address, i.e. Secondary 
address (377) or in an independently decoded Address Space when a Floppy Disk Controller 
is located at the Primary addresses. 
2) Do not install a Floppy and a CompactFlash Storage Card in the system at the same time. 
3) Implement a socket adapter that can be programmed to (conditionally) tri-state D7 of I/0 
address 3F7h/377h when a CompactFlash Storage Card is installed and conversely to tri- 
state D6-DO of I/O address 3F7h/377h when a floppy controller is installed. 
4) Do not use the CompactFlash Storage Card’s Drive Address register. This may be 
accomplished by either a) If possible, program the host adapter to enable only I/O addresses 
1FOh-1F7h, 3F6h (or 170h-177h, 176h) to the CompactFlash Storage Card or b) if provided 
use an additional Primary / Secondary configuration in the CompactFlash Storage Card 
which does not respond to accesses to I/O locations 3F7h and 377h. With either of these 
implementations, the host software shall not attempt to use information in the Drive Address 
Register. 

Bit 6 (-WTG): this bit is 0 when a write operation is in progress; otherwise, it is 1. 

Bit 5 (-HS3): this bit is the negation of bit 3 in the Drive/Head register. 

Bit 4 (-HS2): this bit is the negation of bit 2 in the Drive/Head register. 

Bit 3 (-HS1): this bit is the negation of bit 1 in the Drive/Head register. 

Bit 2 (-HSO): this bit is the negation of bit 0 in the Drive/Head register. 


Bit 1 (-nDS1): this bit is O when drive 1 is active and selected. 


Bit 0 (-nDSO): this bit is O when the drive 0 is active and selected. 
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6.2 CF-ATA Command Description 


This section defines the software requirements and the format of the commands the host sends 
to the CompactFlash Storage Cards. Commands are issued to the CompactFlash Storage Card 
by loading the required registers in the command block with the supplied parameters, and then 
writing the command code to the Command Register. The manner in which a command is 
accepted varies. There are three classes (see Table 45: CF-ATA Command Set) of command 
acceptance, all dependent on the host not issuing commands unless the CompactFlash Storage 
Card is not busy (BSY=0). All commands listed in this specification shall be implemented. 
Commands can be implemented as “no operation” to meet this requirement. The Security Mode 
feature set (Command codes F1, F2, F3, F4, F5, and F6) should not be implemented unless the 
device is intended to be used in an embedded, non-removable application. The Security Mode 
feature set was not designed for removable devices and certain problems may be encountered 
when using these commands in a removable application. This specification introduces some new 
commands and features. If these commands are used on an older CF card, an Invalid Command 
Error may occur. 


= Upon receipt of a Class 1 command, the CompactFlash Storage Card sets BSY within 400 
nsec. 


= Upon receipt of a Class 2 command, the CompactFlash Storage Card sets BSY within 400 
nsec, sets up the sector buffer for a write operation, sets DRQ within 700 usec, and clears 
BSY within 400 nsec of setting DRQ. 


= Upon receipt of a Class 3 command, the CompactFlash Storage Card sets BSY within 400 


nsec, sets up the sector buffer for a write operation, sets DRQ within 20 msec (assuming no 
re-assignments), and clears BSY within 400 nsec of setting DRQ. 
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6.2.1 CF-ATA Command Set 
Table 45: CF-ATA Command Set summarizes the CF-ATA command set with the paragraphs 
that follow describing the individual commands and the task file for each. 


Table 45: CF-ATA Command Set 


: 
[erty Devcs———~idech i 
jo SS~id ere | Pv PP dP 
: 


ae 
Key Management B9 Cc Cc Cc 
Structure Read Feature 0-127 


1 Key Management B9 Cc Cc Cc 
Read Keying Material Feature 80 
2 Key Management Change Cc Cc Cc 
Key Management Value 
OP 


Read DMA C8h Y Y Y 


[4 [Read tongSeaerfaanorzan [PY 
T+ [reastttoe idem dt dP Pv Pv pv 
[4 [readsecots) idem | - |v pv [vy fy] y) 
[+ [reas ventyseaors) _[eohorain | |v |v] v]v |v 
eee ie eee oe 
Ee aa a 
ee ee 
[seoury Ese Propae [ran eee 
SecuriyEraco unt |eam—i— 


F6h 
F3h 
F4h 
F5h 
Fi1h 
F2h 


Security Set Password 


Security Freeze Lock rsh TC 
Security Unlock fron 


7Xh 


Set Features 
Set Multiple Mode 
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[eiess [comma [code [er [so | aw | ov | ow [uma | 
[+ [setseepnede —-[esroren | - | -|-|-]o] — | 
Se 
[4 [stnaty medio etheraen [| [| fe [| 
a 
[4 [Weert iden Si dT dP | dt 
[2 |witosuter iden 


[2 [witsowa idan dP pv Pv pp 
[2 [Wits ton Sear —isenarean | | pv |v fy |v) 


[3 [Wte watipe woes [eon | Pv |v | 
[2 [witeseaors) —_——fatnoram | pv |v 
[2 [Wt secre) woke [en | Pv Pv 
Ts [witevery dscns Pv PT 


Definitions: 


= FR = Features Register 

» SC = Sector Count Register 

= SN = Sector Number Register 

= CY = Cylinder Registers 

" DH = Card/Drive/Head Register 

« LBA = Logical Block Address Mode Supported (see command descriptions for use). 


« Y - The register contains a valid parameter for this command. For the Drive/Head Register Y 
means both the CompactFlash Storage Card and head parameters are used; D - only the 
CompactFlash Storage Card parameter is valid and not the head parameter; C — The register 
contains command specific data (see command descriptions for use). 


6.2.1.1 Check Power Mode - 98h or E5h 


Bit -> 
Command (7 
eine) OOCSCSC*S 
) 


Cyl Low (4 


Sec Num (3) 
Sec Cnt (2) 
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Figure 55: Check Power Mode 


This command checks the power mode. 


If the CompactFlash Storage Card is in, going to, or recovering from the sleep mode, the 
CompactFlash Storage Card sets BSY, sets the Sector Count Register to 00h, clears BSY and 
generates an interrupt. 


If the CompactFlash Storage Card is in Idle mode, the CompactFlash Storage Card sets BSY, 
sets the Sector Count Register to FFh, clears BSY and generates an interrupt. 


6.2.1.2 Execute Drive Diagnostic - 90h 
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Command 
ate 


) 
) 


Sec Cnt (2 
Feature (1) 


Figure 56: Execute Drive Diagnostic 


This command performs the internal diagnostic tests implemented by the CompactFlash Storage 
Card. 


When the diagnostic command is issued in a PCMCIA configuration mode, this command runs 
only on the CompactFlash Storage Card that is addressed by the Drive/Head register. This is 
because PCMCIA card interface does not allows for direct inter-drive communication (such as the 
ATA PDIAG and DASP signals). When the diagnostic command is issued in the True IDE Mode, 
the Drive bit is ignored and the diagnostic command is executed by both the Master and the 
Slave with the Master responding with status for both devices. 


The Diagnostic codes shown in Table 46: Diagnostic Codes are returned in the Error Register at 
the end of the command. 
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Table 46: Diagnostic Codes 


02h Formatter Device Error 
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6.2.1.3 Erase Sector(s) - COh 


[el [es lsl*,s,[? [71] 
i 
[come] 1 [tea [1 [ove | ecotanaray | 


Cyl High (5) Cylinder High (LBA 23-16) 


Cyl Low (4) Cylinder Low (LBA 15-8) 


| Sec Num (3), Sector Number (LBA 7-0) 
Sec Cnt (2) Sector Count 
| Feature) 


Figure 57: Erase Sector 


This command is used to pre-erase and condition data sectors in advance of a Write without 
Erase or Write Multiple without Erase command. There is no data transfer associated with this 
command but a Write Fault error status can occur. 


6.2.1.4 Flush Cache - E7h 
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[el fe lsl*,s,]?7 [71.1 
Ceommnam| em SC*d 
eome)| xi oe | CS 
[ennign@)| SSSCSC~*S 


Cyl Low (4) 


Sec Num (3) 
Sec Cnt (2) 


Feature (1) 


Figure 58: Flush Cache 


This command causes the card to complete writing data from its cache. The card returns status 
with RDY=1 and DSC=1 after the data in the write cache buffer is written to the media. If the 
Compact Flash Storage Card does not support the Flush Cache command, the Compact Flash 
Storage Card shall return command aborted. 
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6.2.1.5 Format Track - 50h 


[el [els l*.s,]? [71] 


Cyl High (5) Cylinder High (LBA 23-16) 


Cyl Low (4) Cylinder Low (LBA 15-8) 


se nu 3) x (BAO 
Sec Cnt (2) Count (LBA mode only) 
| Feature 


Figure 59: Format Track 


This command writes the desired head and cylinder of the selected drive with a vendor unique 
data pattern (typically FFh or 00h). To remain host backward compatible, the CompactFlash 
Storage Card expects a sector buffer of data from the host to follow the command with the same 
protocol as the Write Sector(s) command although the information in the buffer is not used by the 
CompactFlash Storage Card. If LBA=1 then the number of sectors to format is taken from the Sec 
Cnt register (0=256). The use of this command is not recommended. 
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6.2.1.6 
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Identify Device - ECh 


Bit -> 


Command (7) ECh 


= 
as 
oe ee 


Cyl High (5) 


Cyl Low (4) 
SS 


Figure 60: Identify Device 


The Identify Device command enables the host to receive parameter information from the 
CompactFlash Storage Card. This command has the same protocol as the Read Sector(s) 
command. The parameter words in the buffer have the arrangement and meanings defined in 
Table 47. All reserved bits or words are zero. Hosts should not depend on Obsolete words in 
Identify Device containing 0. Table 47 specifies each field in the data returned by the Identify 
Device Command. In Table 47, X indicates a numeric nibble value specific to the card and aaaa 
indicates an ASCII string specific to the particular drive. 


Table 47: Identify Device Information 


Word Default Total Data Field Type Information 
Address Value Bytes 


General configuration - signature for the CompactFlash Storage Card 


General configuration — Bit Significant with ATA-4 definitions. 


[2 Maximum numberof sects on Reade Mule command | 
gale 2 


a 
=a 
Ea 
a 
al 
a 
a 
ial 
[4 Number of sectors per ar (Wd 7 = SW, Woae=LSa) | 
<a 
20 
es 
ee 
= 
Le 
0 


2 
2 
2 
2 
2 
2 
2 
2 
4 
2 
20 
2 
2 
2 
40 
2 
2 
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Word Default Total Data Field Type Information 
Address Value Bytes 

49 XX00h Capabilities 
51 0X00h PIO data transfer cycle timing mode 
52 0000h Obsolete 
53 000Xh Field Validity 
54 XXXXh Current numbers of cylinders 
55 XXXXh Current numbers of heads 
56 XXXXh Current sectors per track 

57-58 XXXXh Current capacity in sectors (LBAs)(Word 57 = LSW, Word 58 = MSW) 
59 01XXh Multiple sector setting 

60-61 XXXXh Total number of sectors addressable in LBA Mode 
63 OX0Xh Multiword DMA transfer. In PCMCIA mode this value shall be Oh 
64 00XXh Advanced PIO modes supported 


65 XXXXh 2 Minimum Multiword DMA transfer cycle time per word. In PCMCIA mode 
this value shall be Oh 
XXXXh 2 Recommended Multiword DMA transfer cycle time. In PCMCIA mode 
this value shall be Oh 


XXXXh Minimum PIO transfer cycle time without flow control 
XXXXh Minimum PIO transfer cycle time with IORDY flow control 
80-81 0000h Reserved — CF cards do not return an ATA version 
82-84 XXXXh i ge <4] Features/command sets supported 
85-87 XXXXh | 6 | Features/command sets enabled 
88 XXXXh ee | Ultra DMA Mode Supported and Selected 
XXXXh ee Time required for Security erase unit completion 
XXXXh Zo Time required for Enhanced security erase unit completion 
91 XXXXh ic oe Current Advanced power management value 
128 XXXXh Security status 
129-159 0000h Vendor unique bytes 
160 XXXXh Power requirement description 
161 0000h Reserved for assignment by the CFA 
162 0000h Key management schemes supported 
163 XXXXh CF Advanced True IDE Timing Mode Capability and Setting 
164 XXXXh CF Advanced PCMCIA I/O and Memory Timing Mode Capability 
165-175 0000h Reserved for assignment by the CFA 
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Word Default Total Data Field Type Information 
Address Value Bytes 


6.2.1.6.1 Word 0: General Configuration 


This field indicates the general characteristics of the device. When Word 0 of the Identify drive 
information is 848Ah then the device is a CompactFlash Storage Card and complies with the CFA 
specification and CFA command set. It is recommended that PCMCIA modes of operation report 
only the 848Ah value as they are always intended as removable devices. 


Bits 15-0: CF Standard Configuration Value 
Word 0 is 848Ah. This is the recommended value of Word 0. 


Some operating systems require Bit 6 of Word 0 to be set to 1 (Non-removable device) to use the 
card as the root storage device. The Card must be the root storage device when a host 
completely replaces conventional disk storage with a CompactFlash Card in True IDE mode. To 
support this requirement and provide capability for any future removable media Cards, alternate 
handling of Word 0 is permitted. 


Bits 15-0: CF Preferred Alternate Configuration Values 
044Ah: This is the alternate value of Word 0 turns on ATA device and turns off Removable 
Media and Removable Device while preserving all Retired bits in the word. 
0040h: This is the alternate value of Word 0 turns on ATA device and turns off Removable 
Media and Removable Device while zeroing all Retired bits in the word 


Bit 15-12: Configuration Flag 
If bits 15:12 are set to 8h then Word 0 shall be 848Ah. 
If bits 15:12 are set to Oh then Bits 11:0 are set using the definitions below and the Card is 
required to support for the CFA command set and report that in bit 2 of Word 83. 
Bit 15:12 values other than 8h and Oh are prohibited. 


Bits 11-8: Retired 
These bits have retired ATA bit definitions. It is recommended that the value of these bits be 
either the preferred value of Oh or the value of 4h that preserves the corresponding bits from 
the 848Ah CF signature value. 


Bit 7: Removable Media Device 
If Bit 7 is set to 1, the Card contains media that can be removed during Card operation. 
If Bit 7 is set to 0, the Card contains nonremovable media. 


Bit 6: Not Removable Controller and/or Device 

Alert! This bit will be considered for obsolescence in a future revision of this standard. 
If Bit 6 is set to 1, the Card is intended to be nonremovable during operation. 
If Bit 6 is set to 0, the Card is intended to be removable during operation. 


Bits 5-0: Retired/Reserved 
Alert! Bit 2 will be considered for definition in a future revision of this standard and shall 
be 0 at this time. 
Bits 5-1 have retired ATA bit definitions. 
Bit 2 shall be 0. 
Bit O is Reserved and shall be 0. 
It is recommended that the value of bits 5-0 be either the preferred value of 00h or the value of 
OAh that preserves the corresponding bits from the 848Ah CF signature value. 
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6.2.1.6.2 Word 1: Default Number of Cylinders 


This field contains the number of translated cylinders in the default translation mode. This value 
will be the same as the number of cylinders. 


6.2.1.6.3 Word 3: Default Number of Heads 
This field contains the number of translated heads in the default translation mode. 


6.2.1.6.4 Word 6: Default Number of Sectors per Track 
This field contains the number of sectors per track in the default translation mode. 


6.2.1.6.5 | Words 7-8: Number of Sectors per Card 


This field contains the number of sectors per CompactFlash Storage Card. This double word 
value is also the first invalid address in LBA translation mode. 


6.2.1.6.6 Words 10-19: Serial Number 


This field contains the serial number for this CompactFlash Storage Card and is right justified and 
padded with spaces (20h). 


6.2.1.6.7. Word 22: ECC Count 


This field defines the number of ECC bytes used on each sector in the Read and Write Long 
commands. This value shall be set to 0004h. 


6.2.1.6.8 | Words 23-26: Firmware Revision 
This field contains the revision of the firmware for this product. 


6.2.1.6.9 Words 27-46: Model Number 


This field contains the model number for this product and is left justified and padded with spaces 
(20h). 


6.2.1.6.10 Word 47: Read/Write Multiple Sector Count 


Bits 15-8 shall be the recommended value of 80h or the permitted value of 00h. Bits 7-0 of this 
word define the maximum number of sectors per block that the CompactFlash Storage Card 
supports for Read/Write Multiple commands. 


6.2.1.6.11 Word 49: Capabilities 


Bit 13: Standby Timer 
If bit 13 is set to 1 then the Standby timer is supported as defined by the IDLE command 
If bit 13 is set to 0 then the Standby timer operation is defined by the vendor. 


Bit 11: IORDY Supported 
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If bit 11 is set to 1 then this CompactFlash Storage Card supports IORDY operation. 
If bit 11 is set to 0 then this CompactFlash Storage Card may support IORDY operation. 


Bit 10: IORDY may be disabled 
Bit 10 shall be set to 0, indicating that IORDY may not be disabled. 


Bit 9: LBA supported 
Bit 9 shall be set to 1, indicating that this CompactFlash Storage Card supports LBA mode 
addressing. CF devices shall support LBA addressing. 


Bit 8: DMA Supported 
If bit 8 is set to 1 then Read DMA and Write DMA commands are supported. 
Bit 8 shall be set to 0. Read/Write DMA commands are not currently permitted on CF cards. 


6.2.1.6.12 Word 51: PIO Data Transfer Cycle Timing Mode 


The PIO transfer timing for each CompactFlash Storage Card falls into modes that have unique 
parametric timing specifications. The value returned in Bits 15-8 shall be OOh for mode 0, 01h for 
mode 1, or 02h for mode 2. Values 03h through FFh are reserved. 


6.2.1.6.13 Word 53: Translation Parameters Valid 


Bit 0 shall be set to 1 indicating that words 54 to 58 are valid and reflect the current number of 
cylinders, heads and sectors. If bit 1 of word 53 is set to 1, the values in words 64 through 70 are 
valid. If this bit is cleared to 0, the values reported in words 64-70 are not valid. Any 
CompactFlash Storage Card that supports PIO mode 3 or above shall set bit 1 of word 53 to one 
and support the fields contained in words 64 through 70. 


6.2.1.6.14 Words 54-56: Current Number of Cylinders, Heads, Sectors/Track 


These fields contains the current number of user addressable Cylinders, Heads, and 
Sectors/Track in the current translation mode. 


6.2.1.6.15 Words 57-58: Current Capacity 
This field contains the product of the current cylinders times heads times sectors. 


6.2.1.6.16 Word 59: Multiple Sector Setting 
Bits 15-9 are reserved and shall be set to 0. 


Bit 8 shall be set to 1 indicating that the Multiple Sector Setting is valid. 
Bits 7-0 are the current setting for the number of sectors that shall be transferred per interrupt on 


Read/Write Multiple commands. 


6.2.1.6.17 Words 60-61: Total Sectors Addressable in LBA Mode 


This field contains the total number of user addressable sectors for the CompactFlash Storage 
Card in LBA mode only. 


6.2.1.6.18 Word 63: Multiword DMA transfer 
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Bits 15 through 8 of word 63 of the Identify Device parameter information is defined as the 
Multiword DMA mode selected field. If this field is supported, bit 1 of word 53 shall be set to one. 
This field is bit significant. Only one of bits may be set to one in this field by the CompactFlash 
Storage Card to indicate the multiword DMA mode which is currently selected. 


Of these bits, bits 15 through 11 are reserved. Bit 8, if set to one, indicates that Multiword DMA 
mode 0 has been selected. Bit 9, if set to one, indicates that Multiword DMA mode 1 has been 
selected. Bit 10, if set to one, indicates that Multiword DMA mode 2 has been selected. 


Selection of Multiword DMA modes 3 and above are specific to CompactFlash are reported in 
word 163 as described in section 6.2.1.6.33: Word 163: CF Advanced True IDE Timing Mode 
Capabilities and Settings. 


Bits 7 through O of word 63 of the Identify Device parameter information is defined as the 
Multiword DMA data transfer supported field. If this field is supported, bit 1 of word 53 shall be set 
to one. This field is bit significant. Any number of bits may be set to one in this field by the 
CompactFlash Storage Card to indicate the Multiword DMA modes it is capable of supporting. 


Of these bits, bits 7 through 2 are reserved. Bit 0, if set to one, indicates that the CompactFlash 
Storage Card supports Multiword DMA mode 0. Bit 1, if set to one, indicates that the 
CompactFlash Storage Card supports Multiword DMA modes 1 and 0. Bit 2, if set to one, 
indicates that the CompactFlash Storage Card supports Multiword DMA modes 2, 1 and 0. 


Support for Multiword DMA modes 3 and above are specific to CompactFlash are reported in 
word 163 as described in section 6.2.1.6.33: Word 163: CF Advanced True IDE Timing Mode 
Capabilities and Settings. 


6.2.1.6.19 Word 64: Advanced PIO transfer modes supported 


Bits 7 through O of word 64 of the Identify Device parameter information is defined as the 
advanced PIO data transfer supported field. If this field is supported, bit 1 of word 53 shall be set 
to one. This field is bit significant. Any number of bits may be set to one in this field by the 
CompactFlash Storage Card to indicate the advanced PIO modes it is capable of supporting. 


Of these bits, bits 7 through 2 are reserved. Bit 0, if set to one, indicates that the CompactFlash 
Storage Card supports PIO mode 3. Bit 1, if set to one, indicates that the CompactFlash Storage 
Card supports PIO mode 4. 


Support for PlO modes 5 and above are specific to CompactFlash are reported in word 163 as 
described in section 6.2.1.6.33: Word 163: CF Advanced True IDE Timing Mode Capabilities and 
Settings. 


6.2.1.6.20 Word 65: Minimum Multiword DMA transfer cycle time 


Word 65 of the parameter information of the Identify Device command is defined as the minimum 
Multiword DMA transfer cycle time. This field defines, in nanoseconds, the minimum cycle time 
that, if used by the host, the CompactFlash Storage Card guarantees data integrity during the 
transfer. 


If this field is supported, bit 1 of word 53 shall be set to one. The value in word 65 shall not be 
less than the minimum cycle time for the fastest DMA mode supported by the device. This field 
shall be supported by all CompactFlash Storage Cards supporting DMA modes 1 and above. 


If bit 1 of word 53 is set to one, but this field is not supported, the Card shall return a value of zero 
in this field. 
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6.2.1.6.21 Word 66: Recommended Multiword DMA transfer cycle time 


Word 66 of the parameter information of the Identify Device command is defined as the 
recommended Multiword DMA transfer cycle time. This field defines, in nanoseconds, the cycle 
time that, if used by the host, may optimize the data transfer from by reducing the probability that 
the CompactFlash Storage Card will need to negate the DMARQ signal during the transfer of a 
sector. 


If this field is supported, bit 1 of word 53 shall be set to one. The value in word 66 shall not be 
less than the value in word 65. This field shall be supported by all CompactFlash Storage Cards 
supporting DMA modes 1 and above. 


If bit 1 of word 53 is set to one, but this field is not supported, the Card shall return a value of zero 
in this field. 


6.2.1.6.22 Word 67: Minimum PIO transfer cycle time without flow control 


Word 67 of the parameter information of the Identify Device command is defined as the minimum 
PIO transfer without flow control cycle time. This field defines, in nanoseconds, the minimum 
cycle time that, if used by the host, the CompactFlash Storage Card guarantees data integrity 
during the transfer without utilization of flow control. 


If this field is supported, Bit 1 of word 53 shall be set to one. 


Any CompactFlash Storage Card that supports PIO mode 3 or above shall support this field, and 
the value in word 67 shall not be less than the value reported in word 68. 


If bit 1 of word 53 is set to one because a CompactFlash Storage Card supports a field in words 
64-70 other than this field and the CompactFlash Storage Card does not support this field, the 
CompactFlash Storage Card shall return a value of zero in this field. 


6.2.1.6.23 Word 68: Minimum PIO transfer cycle time with IORDY 


Word 68 of the parameter information of the Identify Device command is defined as the minimum 
PIO transfer with IORDY flow control cycle time. This field defines, in nanoseconds, the minimum 
cycle time that the CompactFlash Storage Card supports while performing data transfers while 
utilizing IORDY flow control. 


If this field is supported, Bit 1 of word 53 shall be set to one. 


Any CompactFlash Storage Card that supports PIO mode 3 or above shall support this field, and 
the value in word 68 shall be the fastest defined PIO mode supported by the CompactFlash 
Storage Card. 


If bit 1 of word 53 is set to one because a CompactFlash Storage Card supports a field in words 
64-70 other than this field and the CompactFlash Storage Card does not support this field, the 
CompactFlash Storage Card shall return a value of zero in this field. 


6.2.1.6.24 Words 82-84: Features/command sets supported 
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Words 82, 83, and 84 shall indicate features/command sets supported. The value 0000h or 
FFFFh was placed in each of these words by CompactFlash Storage Cards prior to ATA-3 and 
shall be interpreted by the host as meaning that features/command sets supported are not 
indicated. Bits 1 through 13 of word 83 and bits 0 through 13 of word 84 are reserved. Bit 14 of 
word 83 and word 84 shall be set to one and bit 15 of word 83 and word 84 shall be cleared to 
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zero to provide indication that the features/command sets supported words are valid. The values 
in these words should not be depended on by host implementers. 


Bit O of word 82 shall be set to zero; the SMART feature set is not supported. 

If bit 1 of word 82 is set to one, the Security Mode feature set is supported. 

Bit 2 of word 82 shall be set to zero; the Removable Media feature set is not supported. 
Bit 3 of word 82 shall be set to one; the Power Management feature set is supported. 
Bit 4 of word 82 shall be set to zero; the Packet Command feature set is not supported. 
If bit 5 of word 82 is set to one, write cache is supported. 

If bit 6 of word 82 is set to one, look-ahead is supported. 

Bit 7 of word 82 shall be set to zero; release interrupt is not supported. 

Bit 8 of word 82 shall be set to zero; Service interrupt is not supported. 

Bit 9 of word 82 shall be set to zero; the Device Reset command is not supported. 

Bit 10 of word 82 shall be set to zero; the Host Protected Area feature set is not supported. 
Bit 11 of word 82 is obsolete. 


Bit 12 of word 82 shall be set to one; the CompactFlash Storage Card supports the Write Buffer 
command. 


Bit 13 of word 82 shall be set to one; the CompactFlash Storage Card supports the Read Buffer 
command. 


Bit 14 of word 82 shall be set to one; the CompactFlash Storage Card supports the NOP 
command. 


Bit 15 of word 82 is obsolete. 


Bit O of word 83 shall be set to zero; the CompactFlash Storage Card does not support the 
Download Microcode command. 


Bit 1 of word 83 shall be set to zero; the CompactFlash Storage Card does not support the Read 
DMA Queued and Write DMA Queued commands. 


Bit 2 of word 83 shall be set to one; the CompactFlash Storage Card supports the CFA feature 
set. 


If bit 3 of word 83 is set to one, the CompactFlash Storage Card supports the Advanced Power 
Management feature set. 


Bit 4 of word 83 shall be set to zero; the CompactFlash Storage Card does not support the 


Removable Media Status feature set. 


6.2.1.6.25 Words 85-87: Features/command sets enabled 
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Words 85, 86, and 87 shall indicate features/command sets enabled. The value 0000h or FFFFh 
was placed in each of these words by CompactFlash Storage Cards prior to ATA-4 and shall be 
interpreted by the host as meaning that features/command sets enabled are not indicated. Bits 1 
through 15 of word 86 are reserved. Bits 0-13 of word 87 are reserved. Bit 14 of word 87 shall be 
set to one and bit 15 of word 87 shall be cleared to zero to provide indication that the 
features/command sets enabled words are valid. The values in these words should not be 
depended on by host implementers. 

Bit 0 of word 85 shall be set to zero; the SMART feature set is not enabled. 


If bit 1 of word 85 is set to one, the Security Mode feature set has been enabled via the Security 
Set Password command. 


Bit 2 of word 85 shall be set to zero; the Removable Media feature set is not supported. 

Bit 3 of word 85 shall be set to one; the Power Management feature set is supported. 

Bit 4 of word 85 shall be set to zero; the Packet Command feature set is not enabled. 

If bit 5 of word 85 is set to one, write cache is enabled. 

If bit 6 of word 85 is set to one, look-ahead is enabled. 

Bit 7 of word 85 shall be set to zero; release interrupt is not enabled. 

Bit 8 of word 85 shall be set to zero; Service interrupt is not enabled. 

Bit 9 of word 85 shall be set to zero; the Device Reset command is not supported. 

Bit 10 of word 85 shall be set to zero; the Host Protected Area feature set is not supported. 
Bit 11 of word 85 is obsolete. 


Bit 12 of word 85 shall be set to one; the CompactFlash Storage Card supports the Write Buffer 
command. 


Bit 13 of word 85 shall be set to one; the CompactFlash Storage Card supports the Read Buffer 
command. 


Bit 14 of word 85 shall be set to one; the CompactFlash Storage Card supports the NOP 
command. 


Bit 15 of word 85 is obsolete. 


Bit O of word 86 shall be set to zero; the CompactFlash Storage Card does not support the 
Download Microcode command. 


Bit 1 of word 86 shall be set to zero; the CompactFlash Storage Card does not support the Read 
DMA Queued and Write DMA Queued commands. 


If bit 2 of word 86 shall be set to one, the CompactFlash Storage Card supports the CFA feature 
set. 


If bit 3 of word 86 is set to one, the Advanced Power Management feature set has been enabled 
via the Set Features command. 


CF+ & CF SPECIFICATION REV. 3.0 © 1998-2004 COMPACTFLASH ASSOCIATION 


SOFTWARE INTERFACE 


Bit 4 of word 86 shall be set to zero; the CompactFlash Storage Card does not support the 
Removable Media Status feature set. 


6.2.1.6.26 Word 88: Ultra DMA Modes Supported and Selected 
Word 88 identifies the Ultra DMA transfer modes supported by the device and indicates the mode 


that is currently selected. Only one DMA mode shall be selected at any given time. If an Ultra 
DMA mode is selected, then no Multiword DMA mode shall be selected. If a Multiword DMA 
mode is selected, then no Ultra DMA mode shall be selected. Support of this word is mandatory if 
Ultra DMA is supported. 

Bits 15-13: Reserved 

Bit 12: 1 = Ultra DMA mode 4 is selected 0 = Ultra DMA mode 4 is not selected 

Bit 11: 1 = Ultra DMA mode 3 is selected 0 = Ultra DMA mode 3 is not selected 

Bit 10: 1 = Ultra DMA mode 2 is selected 0 = Ultra DMA mode 2 is not selected 

Bit 9: 1 = Ultra DMA mode 1 is selected 0 = Ultra DMA mode 1 is not selected 

Bit 8: 1 = Ultra DMA mode 0 is selected 0 = Ultra DMA mode 0 is not selected 

Bits 7-5: Reserved 

Bit 4: 1 = Ultra DMA mode 4 and below are supported. Bits 0-3 Shall be set to 1. 

Bit 3: 1 = Ultra DMA mode 3 and below are supported, Bits 0-2 Shall be set to 1. 

Bit 2: 1 = Ultra DMA mode 2 and below are supported. Bits 0-1 Shall be set to 1. 

Bit 1: 1 = Ultra DMA mode 1 and below are supported. Bit 0 Shall be set to 1. 


Bit 0: 1 = Ultra DMA mode 0 is supported 


6.2.1.6.27 Word 89: Time required for Security erase unit completion 


Word 89 specifies the time required for the Security Erase Unit command to complete. This 
command shall be supported on CompactFlash Storage Cards that support security. 


| _0 | Value not specified 


1-254 | (Value * 2) minutes 
>508 minutes 


6.2.1.6.28 Word 90: Time required for Enhanced security erase unit completion 


Word 90 specifies the time required for the Enhanced Security Erase Unit command to complete. 
This command shall be supported on CompactFlash Storage Cards that support security. 


| 0 | Value not specified 
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1-254 | (Value * 2) minutes 
>508 minutes 


6.2.1.6.29 Word 91: Advanced power management level value 
Bits 7-0 of word 91 contain the current Advanced Power Management level setting. 


6.2.1.6.30 Word 128: Security Status 


Bit 8: Security Level 
If set to 1, indicates that security mode is enabled and the security level is maximum. 
If set to 0 and security mode is enabled, indicates that the security level is high. 


Bit 5: Enhanced security erase unit feature supported 
If set to 1, indicates that the Enhanced security erase unit feature set is supported. 


Bit 4: Expire 
If set to 1, indicates that the security count has expired and Security Unlock and Security Erase 
Unit are command aborted until a power-on reset or hard reset. 


Bit 3: Freeze 
If set to 1, indicates that the security is Frozen. 


Bit 2: Lock 
If set to 1, indicates that the security is locked. 


Bit 1: Enable/Disable 
If set to 1, indicates that the security is enabled. 
If set to 0, indicates that the security is disabled. 


Bit 0: Capability 
If set to 1, indicates that CompactFlash Storage Card supports security mode feature set. 
If set to 0, indicates that CompactFlash Storage Card does not support security mode feature 
set. 


6.2.1.6.31 Word 160: Power Requirement Description 
This word is required for CompactFlash Storage Cards that support power mode 1. 


Bit 15: VLD 
If set to 1, indicates that this word contains a valid power requirement description. 
If set to 0, indicates that this word does not contain a power requirement description. 


Bit 14: RSV 
This bit is reserved and shall be 0. 

Bit 13: -XP 
If set to 1, indicates that the CompactFlash Storage Card does not have Power Level 1 
commands. 


If set to 0, indicates that the CompactFlash Storage Card has Power Level 1 commands 


Bit 12: -XE 
If set to 1, indicates that Power Level 1 commands are disabled. 
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If set to 0, indicates that Power Level 1 commands are enabled. 


Bit 0-11: Maximum current 
This field contains the CompactFlash Storage Card’s maximum current in mA. 


6.2.1.6.32 Word 162: Key Management Schemes Supported 
Bit 0: CPRM support 
If set to 1, the device supports CPRM Scheme (Content Protection for Recordable Media) 
If set to 0, the device does not support CPRM. 


Bits 1-15 are reserved for future additional Key Management schemes. 


6.2.1.6.33 Word 163: CF Advanced True IDE Timing Mode Capabilities and Settings 


This word describes the capabilities and current settings for CFA defined advanced timing modes 
using the True IDE interface. 


Notice! The use of True IDE PIO Modes 5 and above or of Multiword DMA Modes 3 and 
above impose significant restrictions on the implementation of the host as indicated in 
section 4.3.7: Additional Requirements for CF Advanced Timing Modes. 


There are four separate fields defined that describe support and selection of Advanced PIO 
timing modes and Advanced Multiword DMA timing modes. The older modes are reported in 
words 63 and 64 as described in sections 6.2.1.6.18: Word 63: Multiword DMA transfer and 
6.2.1.6.19: Word 64: Advanced PIO transfer modes supported. 


Bits 2-0: Advanced True IDE PIO Mode Support 
Indicates the maximum True IDE PIO mode supported by the card. 


Maximum PIO mode timing supported 
| _0 __| Specified in word 64 


PIO Mode 5 
PIO Mode 6 


Bits 5-3: Advanced True IDE Multiword DMA Mode Support 
Indicates the maximum True IDE Multiword DMA mode supported by the card. 


Maximum Multiword DMA timing mode supported 
| 0 __| Specified in word 63 


Multiword DMA Mode 3 
Multiword DMA Mode 4 
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Bits 8-6: Advanced True IDE PIO Mode Selected 
Indicates the current True IDE PIO mode selected on the card. 


Current PIO timing mode selected 
| 0 | Specified in word 64 


PIO Mode 5 
PIO Mode 6 


Bits 11-9: Advanced True IDE Multiword DMA Mode Selected 
Indicates the current True IDE Multiword DMA Mode Selected on the card. 


Current Multiword DMA timing mode selected 
| _0 __| Specified in word 63 


Multiword DMA Mode 3 
Multiword DMA Mode 4 


Bits 15-12 are reserved. 


6.2.1.6.34 Word 164: CF Advanced PCMCIA I/O and Memory Timing Modes Capabilities and Settings 


This word describes the capabilities and current settings for CFA defined advanced timing modes 
using the Memory and PCMCIA I/O interface. 


Notice! The use of PCMCIA I/O or Memory modes that are 100ns or faster impose 
significant restrictions on the implementation of the host as indicated in section 4.3.7: 
Additional Requirements for CF Advanced Timing Modes. 


Bits 2-0: Maximum Advanced PCMCIA I/O Mode Support 
Indicates the maximum I/O timing mode supported by the card. 


Maximum PCMCIA IO timing mode supported 
| 0 | 255 ns Cycle PCMCIA I/O Mode 
120 ns Cycle PCMCIA I/O Mode 


100 ns Cycle PCMCIA I/O Mode 
80 ns Cycle PCMCIA I/O Mode 


Bits 5-3: Maximum Memory timing mode supported 
Indicates the Maximum Memory timing mode supported by the card. 


Maximum Memory timing mode Supported 
| 0 | 250 ns Cycle Memory Mode 
120 ns Cycle Memory Mode 


100 ns Cycle Memory Mode 
80 ns Cycle Memory Mode 


Bits 15-6: Reserved. 


6.2.1.7 Idle - 97h or E3h 
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Bit -> 7 6 5 4 3 2 1 0 
Command (7) 97h or E3h 
C/D/H (6) X X 

Cyl High (5) X 

Cyl Low (4) Xx 
Sec Num (3) Xx 

Sec Cnt (2) Timer Count (5 msec increments) 

Feature (1) xX 

Figure 61: Idle 


This command causes the CompactFlash Storage Card to set BSY, enter the Idle mode, clear 
BSY and generate an interrupt. If the sector count is non-zero, it is interpreted as a timer count 
with each count being 5 milliseconds and the automatic power down mode is enabled. If the 
sector count is zero, the automatic power down mode is disabled. Note that this time base (5 
msec) is different from the ATA specification. 


6.2.1.8 Idle Immediate - 95h or Eth 


Bit -> 7 6 5 4 3 2 1 0 
Command (7) 95h or Eth 
C/D/H (6) X Drive X 

Cyl High (5) 
Cyl Low (4) 
Sec Num (3) 
Sec Cnt (2) 
Feature (1) Xx 


Figure 62: Idle Immediate 


This command causes the CompactFlash Storage Card to set BSY, enter the Idle mode, clear 
BSY and generate an interrupt. 


6.2.1.9 Initialize Drive Parameters - 91h 


Bit -> 7 6 5 4 3 2 1 0 
Command (7) 91h 
C/D/H (6) X 0 Xx Drive Max Head (no. of heads-1) 
Cyl High (5) X 
Cyl Low (4) 
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Sec Num (3) Xx 
Sec Cnt (2) Number of Sectors 
Feature (1) xX 


Figure 63: Initialize Drive Parameters 


This command enables the host to set the number of sectors per track and the number of heads 
per cylinder. Only the Sector Count and the Card/Drive/Head registers are used by this 
command. 
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6.2.1.10 Key Management Structure Read - B9h (Feature: 0-127) 


Bit -> 7 6 5 4 3 2 1 0 
Command (7) B9h 
C/D/H (6) Reserved (0) Drive Reserved (0) 
Cyl High (5) C7-0 
Cyl Low (4) C15-8 
Sec Num (3) C23-16 
Sec Cnt (2) C31-24 
Feature (1) 0 C38-32 


Figure 64: Key Management Structure Read 


The KEY MANAGEMENT STRUCTURE READ command is optional, depending on the Key 
Management scheme in use. 


This command returns a 512-byte Key Management data structure via PIO data-in transfer. The 
structure encodes device Key Management status defined by the Key Management scheme in 
use. In some schemes, this structure may include a cryptographic response. 


The values 39-bit value C38-0 is a random number picked by the host. It is used as a challenge 
value by some Key Management schemes. All 39-bit values are acceptable. 


6.2.1.11 Key Management Read Keying Material - B9h (Feature: 80) 


Bit -> 7 6 5 4 3 2 1 0 
Command (7) B9h 
C/D/H (6) Reserved (0) Drive Reserved (0) 

Cyl High (5) Reserved (0) 

Cyl Low (4) Keying Material Sector Offset - High 
Sec Num (3) Keying Material Sector Offset - Low 

Sec Cnt (2) Keying Material Count 

Feature (1) 80h 


Figure 65: Key Management Read Keying Material 


The KEY MANAGEMENT READ KEYING MATERIAL command is optional, depending on the 
Key Management scheme in use. 


This command reads from 1 to 256 sectors as specified in the Sector Count register. A Sector 
Count of 0 requests 256 sectors. The transfer shall begin at the Sector Offset within the keying 
material specified in the 16 bit number comprised of the Sector Number and Cylinder Low 
registers. The size and format of the keying material is specific to the Key Management scheme 
in use. 
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If an uncorrectable error occurs reading the keying material, the Sector Number and Cylinder Low 
registers are left indicating the offset of the sector in error. 


6.2.1.12 Key Management Change Key Management Value - B9h (Feature: 81) 


Bit -> 7 6 5 4 3 2 1 0 
Command (7) B9h 
C/D/H (6) Reserved (0) Drive Reserved (0) 
Cyl High (5) B2h 
Cyl Low (4) 6Eh 
Sec Num (3) Reserved (0) 
Sec Cnt (2) Reserved (0) 
Feature (1) 81h 


Figure 66: Key Management Change Key Management Value 


The KEY MANAGEMENT CHANGE KEY MANAGEMENT VALUE command is optional, 
depending on the Key Management scheme in use. 


This command causes the device to change a value found in the KEY MANAGEMENT READ 
KEY MANAGEMENT STRUCTURE response. The method is specific to the Key Management 
scheme in use. The special value B26Eh in the cylinder registers is checked by the card to make 
it less likely that the command was executed by mistake. 


6.2.1.13 NOP - 00h 


Bit -> 7 6 5 4 3 2 1 0 
Command (7) 00h 
C/D/H (6) X Drive X 

Cyl High (5) 
Cyl Low (4) 
Sec Num (3) 
Sec Cnt (2) 
Feature (1) 


x |x | kK | xk LX 


Figure 67: NOP 


This command always fails with the CompactFlash Storage Card returning command aborted. 
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6.2.1.14 Read Buffer - E4h 


Bit -> 7 6 5 4 3 2 1 0 
Command (7) E4h 
C/D/H (6) X Drive X 

Cyl High (5) 
Cyl Low (4) 
Sec Num (3) 
Sec Cnt (2) 
Feature (1) 


x |< | xk |x | xX 


Figure 68: Read Buffer 


The Read Buffer command enables the host to read the current contents of the CompactFlash 
Storage Card’s sector buffer. This command has the same protocol as the Read Sector(s) 
command. 


6.2.1.15 Read DMA - C8h 


Bit -> 7 6 5 4 3 2 1 0 
Command (7) C8h 
C/D/H (6) 1 LBA 1 Drive Head (LBA 27-24) 

Cyl High (5) Cylinder High (LBA 23-16) 

Cyl Low (4) Cylinder Low (LBA 15-8) 
Sec Num (3) Sector Number (LBA 7-0) 

Sec Cnt (2) Sector Count 

Feature (1) xX 


Figure 69: Read DMA 


This command uses DMA mode to read from 1 to 256 sectors as specified in the Sector Count 
register. A sector count of 0 requests 256 sectors. The transfer begins at the sector specified in 
the Sector Number Register. When this command is issued the CompactFlash Storage Card sets 
BSY, puts all or part of the sector of data in the buffer. The Card is then permitted, although not 
required, to set DRQ, clear BSY. The Card asserts DMAREQ while data is available to be 
transferred. The Card asserts DMAREQ while data is available to be transferred. The host then 
reads the (512 * sector-count) bytes of data from the Card using DMA. While DMAREQ is 
asserted by the Card, the Host asserts -DMACK while it is ready to transfer data by DMA and 
asserts -IORD once for each 16 bit word to be transferred to the Host. 


Interrupts are not generated on every sector, but upon completion of the transfer of the entire 
number of sectors to be transferred or upon the occurrence of an unrecoverable error. 


At command completion, the Command Block Registers contain the cylinder, head and sector 
number of the last sector read. If an error occurs, the read terminates at the sector where the 
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error occurred. The Command Block Registers contain the cylinder, head, and sector number of 
the sector where the error occurred. The amount of data transferred is indeterminate. 


When a Read DMA command is received by the Card and 8 bit transfer mode has been enabled 
by the Set Features command, the Card shall return the Aborted error. 


6.2.1.16 Read Long Sector - 22h or 23h 
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Bit -> 6 5 4 3 2 1 0 
Command (7) 22h or 23h 
C/D/H (6) LBA 1 Drive Head (LBA 27-24) 
Cyl High (5) Cylinder High (LBA 23-16) 
Cyl Low (4) Cylinder Low (LBA 15-8) 
Sec Num (3) Sector Number (LBA 7-0) 
Sec Cnt (2) 


Feature (1) 


Figure 70: Read Long Sector 


The Read Long command performs similarly to the Read Sector(s) command except that it 
returns 516 bytes of data instead of 512 bytes. During a Read Long command, the CompactFlash 
Storage Card does not check the ECC bytes to determine if there has been a data error. Only 
single sector read long operations are supported. The transfer consists of 512 bytes of data 
transferred in word mode followed by 4 bytes of ECC data transferred in byte mode. This 
command has the same protocol as the Read Sector(s) command. Use of this command is not 


recommended. 
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6.2.1.17 Read Multiple - C4h 


Bit -> 7 6 5 4 3 2 1 0 
Command (7) C4h 
C/D/H (6) 1 LBA 1 Drive Head (LBA 27-24) 

Cyl High (5) Cylinder High (LBA 23-16) 

Cyl Low (4) Cylinder Low (LBA 15-8) 
Sec Num (3) Sector Number (LBA 7-0) 

Sec Cnt (2) Sector Count 

Feature (1) Xx 


Figure 71: Read Multiple 


Note: This specification requires that CompactFlash Cards support a multiple block count of 1 and permits 
larger values to be supported. 


The Read Multiple command performs similarly to the Read Sectors command. Interrupts are not 
generated on every sector, but on the transfer of a block, which contains the number of sectors 
defined by a Set Multiple command. 


Command execution is identical to the Read Sectors operation except that the number of sectors 
defined by a Set Multiple command is transferred without intervening interrupts. DRQ qualification 
of the transfer is required only at the start of the data block, not on each sector. 


The block count of sectors to be transferred without intervening interrupts is programmed by the 
Set Multiple Mode command, which shall be executed prior to the Read Multiple command. When 
the Read Multiple command is issued, the Sector Count Register contains the number of sectors 
(not the number of blocks or the block count) requested. If the number of requested sectors is not 
evenly divisible by the block count, as many full blocks as possible are transferred, followed by a 
final, partial block transfer. The partial block transfer is for n sectors, where 


n = (sector count) modulo (block count). 


If the Read Multiple command is attempted before the Set Multiple Mode command has been 
executed or when Read Multiple commands are disabled, the Read Multiple operation is rejected 
with an Aborted Command error. Disk errors encountered during Read Multiple commands are 
posted at the beginning of the block or partial block transfer, but DRQ is still set and the data 
transfer shall take place as it normally would, including transfer of corrupted data, if any. 


Interrupts are generated when DRQ is set at the beginning of each block or partial block. The 
error reporting is the same as that on a Read Sector(s) Command. This command reads from 1 
to 256 sectors as specified in the Sector Count register. A sector count of 0 requests 256 sectors. 
The transfer begins at the sector specified in the Sector Number Register. 


At command completion, the Command Block Registers contain the cylinder, head and sector 
number of the last sector read. 


If an error occurs, the read terminates at the sector where the error occurred. The Command 


Block Registers contain the cylinder, head and sector number of the sector where the error 
occurred. The flawed data is pending in the sector buffer. 
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Subsequent blocks or partial blocks are transferred only if the error was a correctable data error. 
All other errors cause the command to stop after transfer of the block that contained the error. 


6.2.1.18 Read Sector(s) - 20h or 21h 


Feature (1) 


Bit -> 6 5 4 3 2 1 0 
Command (7) 20h or 21h 
C/D/H (6) LBA 1 Drive Head (LBA 27-24) 
Cyl High (5) Cylinder High (LBA 23-16) 
Cyl Low (4) Cylinder Low (LBA 15-8) 
Sec Num (3) Sector Number (LBA 7-0) 
Sec Cnt (2) Sector Count 


X 


Figure 72: Read Sector(s) 


This command reads from 1 to 256 sectors as specified in the Sector Count register. A sector 
count of 0 requests 256 sectors. The transfer begins at the sector specified in the Sector Number 
Register. When this command is issued and after each sector of data (except the last one) has 
been read by the host, the CompactFlash Storage Card sets BSY, puts the sector of data in the 
buffer, sets DRQ, clears BSY, and generates an interrupt. The host then reads the 512 bytes of 
data from the buffer. 


At command completion, the Command Block Registers contain the cylinder, head and sector 
number of the last sector read. If an error occurs, the read terminates at the sector where the 
error occurred. The Command Block Registers contain the cylinder, head, and sector number of 
the sector where the error occurred. The flawed data is pending in the sector buffer. 


6.2.1.19 Read Verify Sector(s) - 40h or 41h 


Command (7) 


C/DIH (6) 


Cyl High (5) 


Cyl Low (4) 


Sec Num (3) 


Sec Cnt (2) 


Feature (1) 


Bit -> 7 6 5 4 3 2 1 0 
40h or 41h 
LBA 1 Drive Head (LBA 27-24) 


Cylinder High (LBA 23-16) 
Cylinder Low (LBA 15-8) 
Sector Number (LBA 7-0) 

Sector Count 


X 


Figure 73: Read Verify Sector(s) 


This command is identical to the Read Sectors command, except that DRQ is never set and no 
data is transferred to the host. When the command is accepted, the CompactFlash Storage Card 
sets BSY. 
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When the requested sectors have been verified, the CompactFlash Storage Card clears BSY and 
generates an interrupt. Upon command completion, the Command Block Registers contain the 
cylinder, head, and sector number of the last sector verified. 


If an error occurs, the Read Verify Command terminates at the sector where the error occurs. The 


Command Block Registers contain the cylinder, head and sector number of the sector where the 
error occurred. The Sector Count Register contains the number of sectors not yet verified. 


6.2.1.20 Recalibrate - 1Xh 


Bit -> 7 6 5 4 3 2 1 0 
Command (7) 1Xh 
C/D/H (6) 1 LBA 1 Drive X 

Cyl High (5) 
Cyl Low (4) 
Sec Num (3) 
Sec Cnt (2) 
Feature (1) 


x |x 1K |x [xX 


Figure 74: Recalibrate 


This command is effectively a NOP command to the CompactFlash Storage Card and is provided 
for compatibility purposes. 


6.2.1.21 Request Sense - 03h 


Bit -> 7 6 5 4 3 2 1 0 
Command (7) 03h 
C/D/H (6) 1 X 1 Drive X 

Cyl High (5) 
Cyl Low (4) 
Sec Num (3) 
Sec Cnt (2) 
Feature (1) 


x |x |x |< | x< 


Figure 75: Request Sense 


This command requests extended error information for the previous command. Table 48 defines 
the valid extended error codes for the CompactFlash Storage Card Series product. The extended 
error code is returned to the host in the Error Register. 
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Table 48: Extended Error Codes 


6.2.1.22 Security Disable Password - F6h 


134 


Bit -> 7 6 5 4 3 2 1 0 


Command (7) F6h 


C/D/H (6) 1 LBA 1 Drive X 


Cyl High (5) 


Cyl Low (4) 


Sec Num (3) 


Sec Cnt (2) 


x |x 1K |x [xX 


Feature (1) 


Figure 76: Security Disable Password 


This command requests a transfer of a single sector of data from the host. Table 49 defines the 
content of this sector of information. If the password selected by word 0 matches the password 
previously saved by the device, the device disables the lock mode. This command does not 
change the Master password that may be reactivated later by setting a User password. Use of 
this command is not recommended by the CFA. 
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Table 49: Security Password Data Content 


a 


Control word 


Bit 0: identifier 
0=compare User password 


1=compare Master password 
Bit 1-15: Reserved 


6.2.1.23 Security Erase Prepare - F3h 


Bi eee if 8 Wp me a) aM 58. ie, te oe 
[commana] SSCSCSCS~CS*S 
| comet 4 | ces | ot | ove | 
oii] SCS 
Sec Cnt (2) 
Feature (1) 


Figure 77: Security Erase Prepare 


This command shall be issued immediately before the Security Erase Unit command to enable 
device erasing and unlocking. This command prevents accidental erase of the CompactFlash 
Storage Card. Use of this command is not recommended by the CFA. 


6.2.1.24 Security Erase Unit - F4h 


[sl [es fs l*ps]? [7] 
Teoma SSSC~*” 
com) 7 [wa [a [owe | xC*S 

a 


Cyl High (5) 


Cyl Low (4) 


Figure 78: Security Erase Unit 
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This command requests transfer of a single sector of data from the host. Table 49 defines the 
content of this sector of information. If the password does not match the password previously 
saved by the CompactFlash Storage Card, the CompactFlash Storage Card rejects the command 
with command aborted. The Security Erase Prepare command shall be completed immediately 
prior to the Security Erase Unit command. If the CompactFlash Storage Card receives a Security 
Erase Unit command without an immediately prior Security Erase Prepare command, the 
CompactFlash Storage Card command aborts the Security Erase Unit command. Use of this 
command is not recommended by the CFA. 


6.2.1.25 Security Freeze Lock - F5h 


136 


[esl [De fs pe 
Teommna@| CSSCS*~*r 
come] 7 [wa [a Dome |S 

[eae er 


Cyl High (5) 


Sec Num (3) 


a es 


Figure 79: Security Freeze Lock 


The Security Freeze Lock command sets the CompactFlash Storage Card to Frozen mode. After 
command completion, any other commands that update the CompactFlash Storage Card Lock 
mode are rejected. Frozen mode is disabled by power off or hardware reset. If Security Freeze 
Lock is issued when the CompactFlash Storage Card is in Frozen mode, the command executes 
and the CompactFlash Storage Card remains in Frozen mode. After command completion, the 
Sector Count Register shall be set to 0. Use of this command is not recommended by the CFA. 


Commands disabled by Security Freeze Lock are: 


= Security Set Password 

= Security Unlock 

= Security Disable Password 
= Security Erase Unit 


If security mode feature set is not supported, this command shall be handled as Wear Level 
command. 
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6.2.1.26 Security Set Password - F1h 


[sl [els l*ls,[? [71] 
Teoma mSCSSCSC~*r 
come] + [wa [a Dom |S 

ee 


Cyl High (5) 
cy] SSCSC~“—~sSC~“—s‘ SSSCSSCSCSCS~™~SOSOCSC*d 


Figure 80: Security Set Password 


This command requests a transfer of a single sector of data from the host. Table 50 defines the 
content of the sector of information. The data transferred controls the function of this command. 
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Table 51 defines the interaction of the identifier and security level bits. Use of this command is 
not recommended by the CFA. 


Table 50: Security Set Password Data Content 


Control word 


Bit 0: Identifier 
O=set User password 
1=set Master password 


Bits 1-7: Reserved 


Bit 8: Security level 
O=High 
1=Maximum 


Bits 9-15: Reserved 
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Table 51: Identifier and Security Level Bit Interaction 


[Identifier _| Level Command result 


User High The password supplied with the command shall be saved as the 
new User password. The lock mode shall be enabled from the 
next power-on or hardware reset. The CompactFlash Storage 
Card shall then be unlocked by either the User password or the 
previously set Master password. 


User Maximum The password supplied with the command shall be saved as the 
new user password. The lock mode shall be enabled from the 
next power-on reset or hardware reset. The CompactFlash 
Storage Card shall then be unlocked by only the User password. 
The Master password previously set is still stored in the 
CompactFlash Storage Card shall not be used to unlock the 
CompactFlash Storage Card. 

Master High or Maximum This combination shall set a Master password but shall not 
enable or disable the Lock mode. The security level is not 
changed. 


6.2.1.27 Security Unlock - F2h 


CT OSOSOSOSCSCSC“‘“‘S 


Cyl High (5) 


Figure 81: Security Unlock 


This command requests transfer of a single sector of data from the host. Table 49 defines the 
content of this sector of information. If the identifier bit is set to Master and the device is in high 
security level, then the password supplied shall be compared with the stored Master password. If 
the device is in the maximum security level, then the unlock command shall be rejected. If the 
identifier bit is set to user, then the device compares the supplied password with the stored User 
password. If the password compare fails then the device returns command aborted to the host 
and decrements the unlock counter. This counter is initially set to five and is decremented for 
each password mismatch when Security Unlock is issued and the device is locked. Once this 
counter reaches zero, the Security Unlock and Security Erase Unit commands are command 
aborted until after a power-on reset or a hardware reset is received. Security Unlock commands 
issued when the device is unlocked have no effect on the unlock counter. Use of this command is 
not recommended by the CFA. 
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6.2.1.28 Seek - 7Xh 


[el [es flsl*,s,[? [711] 
a 


Cyl High (5) Cylinder High (LBA 23-16) 


Cyl Low (4) Cylinder Low (LBA 15-8) 


see num 0) BA 72) 
Sec Cnt 
[Feature (| Sd 


Figure 82: Seek 


This command is effectively a NOP command to the CompactFlash Storage Card although it 
does perform a range check of cylinder and head or LBA address and returns an error if the 
address is out of range. 


6.2.1.29 Set Features — EFh 


[esl Pe tsl[*l[s,?7]*7]° 
a: 


Cyl High (5) X 


Sec Cnt (2) 
Feature (1) Feature 


Figure 83: Set Features 


This command is used by the host to establish or select certain features. If any subcommand 
input value is not supported or is invalid, the Compact Flash Storage Card shall return command 
aborted. Table 52: Feature Supported defines all features that are supported. 
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Table 52: Feature Supported 


| Feature | Operation 
Enable 8 bit data transfers. 
Enable Write Cache. 


Enable Extended Power operations. (Alert: It has been proposed to remove this 
feature from a future revision of the specification. Please notify the CFA if you 
have a requirement for this feature.) 


03h 
05h 
09h 
OAh 
44h 
55h 
66h 
69h 
82h 
85h 
89h Disable Extended Power operations. (Alert: It has been proposed to remove this 
8Ah 
96h 
97h 
9Ah 
BBh 
CCh 


feature from a future revision of the specification. Please notify the CFA if you 
have a requirement for this feature.) 


AAh 


Features 01h and 81th are used to enable and clear 8 bit data transfer modes in True IDE Mode. 
If the 01h feature command is issued all data transfers shall occur on the low order D[7:0] data 
bus and the -IOIS16 signal shall not be asserted for data register accesses. The host shall not 
enable this feature for DMA transfers. 


Features 02h and 82h allow the host to enable or disable write cache in CompactFlash Storage 
Cards that implement write cache. When the subcommand disable write cache is issued, the 
CompactFlash Storage Card shall initiate the sequence to flush cache to non-volatile memory 
before command completion. 


Feature 03h allows the host to select the PIO or Multiword DMA transfer mode by specifying a 
value in the Sector Count register. The upper 5 bits define the type of transfer and the low order 3 
bits encode the mode value. One PIO mode shall be selected at all times. For Cards which 
support DMA, one Multiword DMA mode shall be selected at all times. The host may change the 
selected modes by the Set Features command. 
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Table 53: Transfer mode values 


Mode Bits (7:3) Bits (2:0) 
PIO default mode 00000b 000b 
PIO default mode, disable IORDY 00000b 001b 
PIO flow control transfer mode 00001b Mode 
Reserved 00010b N/A 
Multiword DMA mode 00100b Mode 
Ultra DMA Mode 01000b Mode 
Reserved 10000b N/A 
Mode = transfer mode number 


If a CompactFlash Storage Card supports PIO modes greater than 0 and receives a Set Features 
command with a Set Transfer Mode parameter and a Sector Count register value of “OOO00000b”, 
it shall set its default PIO mode. If the value is “O0000001b” and the CompactFlash Storage Card 
supports disabling of IORDY, then the CompactFlash Storage Card shall set its default PIO mode 
and disable IORDY. A CompactFlash Storage Card shall support all PIO modes below the 
highest mode supported, e.g., if PIO mode 1 is supported PIO mode 0 shall be supported. 


Support of IORDY is mandatory when PIO mode 3 or above is the current mode of operation. 


A CompactFlash Storage Card reporting support for Multiword DMA modes shall support all 
Multiword DMA modes below the highest mode supported. For example, if Multiword DMA mode 
2 support is reported, then modes 1 and 0 shall also be supported. 


A CompactFlash Storage Card reporting support for Ultra DMA modes shall support all Ultra DMA 
modes below the highest mode supported. For example, if Ultra DMA mode 2 support is reported 
then modes 1 and 0 shall also be supported. 


If an Ultra DMA mode is enabled any previously enabled Multiword DMA mode shall be disabled 
by the device. If a Multiword DMA mode is enabled any previously enabled Ultra DMA mode shall 
be disabled by the device. Feature 05h allows the host to enable Advanced Power Management. 
To enable Advanced Power Management, the host writes the Sector Count register with the 
desired advanced power management level and then executes a Set Features command with 
subcommand code 05h. The power management level is a scale from the lowest power 
consumption setting of 01h to the maximum performance level of FEh. Table 54: Advanced 
power management levels shows these values. 


Table 54: Advanced power management levels 


Level Sector Count 
Value 


Intermediate power management levels without 81h-FDh 
Standby 


Minimum power consumption without Standb 


Intermediate power management levels with 02h-7Fh 
Standby 


Minimum power consumption with Standby 


Device performance may increase with increasing power management levels. Device power 
consumption may increase with increasing power management levels. The power management 
levels may contain discrete bands. For example, a device may implement one power 
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management method from 80h to AOh and a higher performance, higher power consumption 
method from level A1h to FEh. Advanced power management levels 80h and higher do not 
permit the device to spin down to save power. 


Feature 85h disables Advanced Power Management. Subcommand 85h may not be implemented 
on all devices that implement Set Features subcommand O5h. 


Features OAh and 8Ah are used to enable and disable Power Level 1 commands. Feature OAh is 
the default feature for the CompactFlash Storage Card with extended power. 


Features 55h and BBh are the default features for the CompactFlash Storage Card; thus, the host 
does not have to issue this command with these features unless it is necessary for compatibility 
reasons. 


Feature code 9Ah enables the host to configure the card to best meet the host system’s power 
requirements. The host sets a value in the Sector Count register that is equal to one-fourth of the 
desired maximum average current (in mA) that the card should consume. For example, if the 
Sector Count register were set to 6, the card would be configured to provide the best possible 
performance without exceeding 24 mA. Upon completion of the command, the card responds to 
the host with the range of values supported by the card. The minimum value is set in the Cylinder 
Low register, and the maximum value is set in the Cylinder Hi register. The default value, after a 
power on reset, is to operate at the highest performance and therefore the highest current mode. 
The card shall accept values outside this programmable range, but shall operate at either the 
lowest power or highest performance as appropriate. 


Features 66h and CCh can be used to enable and disable whether the Power On Reset (POR) 
Defaults shall be set when a soft reset occurs. The default setting is to revert to the POR defaults 
when a soft reset occurs. 


6.2.1.30 Set Multiple Mode - C6h 


f= ae eee a 


Cyl Low (4) 
See Num () 
Sec Cnt (2) Sector Count 

Feature (1) 


Figure 84: Set Multiple Mode 


This command enables the CompactFlash Storage Card to perform Read and Write Multiple 
operations and establishes the block count for these commands. The Sector Count Register is 
loaded with the number of sectors per block. Upon receipt of the command, the CompactFlash 
Storage Card sets BSY to 1 and checks the Sector Count Register. 


If the Sector Count Register contains a valid value and the block count is supported, the value is 
loaded and execution is enabled for all subsequent Read Multiple and Write Multiple commands. 
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If the block count is not supported, an Aborted Command error is posted and the Read Multiple 
and Write Multiple commands are disabled. If the Sector Count Register contains 0 when the 
command is issued, Read and Write Multiple commands are disabled. At power on, or after a 
hardware or (unless disabled by a Set Feature command) software reset, the default mode is 
Read and Write Multiple disabled. 
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6.2.1.31 Set Sleep Mode- 99h or E6h 


[el [els l*ts,[? [7] 
[ennign)| CSCi‘aRSSSSSSCS*d 


Cyl Low (4) 


Figure 85: Set Sleep Mode 


This command causes the CompactFlash Storage Card to set BSY, enter the Sleep mode, clear 
BSY and generate an interrupt. Recovery from sleep mode is accomplished by simply issuing 
another command (a reset is permitted but not required). Sleep mode is also entered when 
internal timers expire so the host does not need to issue this command except when it wishes to 
enter Sleep mode immediately. The default value for the timer is 5 milliseconds. Note that this 
time base (5 msec) is different from the ATA Specification. 


6.2.1.32 Standby - 96h or E2h 


esl Pe ts ls lst?) 
Teynisn yf 


Cyl Low (4) 
secom@ | SSSOSCSC~“~SC~—<‘GRSSSCSCSC‘“‘~*S*S 


Figure 86: Standby 


This command causes the CompactFlash Storage Card to set BSY, enter the Sleep mode (which 
corresponds to the ATA “Standby” Mode), clear BSY and return the interrupt immediately. 
Recovery from sleep mode is accomplished by simply issuing another command (a reset is not 
required). 
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6.2.1.33 Standby Immediate - 94h or EOh 


[el [es flsl*,ls,[? [71] 
[ennign@)| CiSSSSCSC~*S 


Cyl Low (4) 


Figure 87: Standby Immediate 


This command causes the CompactFlash Storage Card to set BSY, enter the Sleep mode (which 
corresponds to the ATA “Standby” Mode), clear BSY and return the interrupt immediately. 
Recovery from sleep mode is accomplished by simply issuing another command (a reset is not 
required). 


6.2.1.34 Translate Sector - 87h 


se [se pete fet 
re 
[com ef 7 [ee [a ome [read tear 


Cyl High (5) Cylinder High (LBA 23-16) 


Cyl Low (4) Cylinder Low (LBA 15-8) 


Sector Number (LBA 7-0) 


Soe Cnt 
Feature () 


Figure 88: Translate Sector 


This command allows the host a method of determining the exact number of times a user sector 
has been erased and programmed. The controller responds with a 512 byte buffer of information 
containing the desired cylinder, head and sector, including its Logical Address, and the Hot 
Count, if available, for that sector. Table 55 represents the information in the buffer. Please note 
that this command is unique to the CompactFlash Storage Card. 
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Table 55: Translate Sector Information 


[reaiess [tomas 


Notes 1) A value of 0 indicates Hot Count is not supported. 


6.2.1.35 Wear Level - F5h 


Bit -> 


Command (7) 


ee 
eon] x [x [x [one [ra 
a 


Cyl High (5) 


Sec Cnt (2) Completion Status 
| Feature yf 


Figure 89: Wear Level 


For the CompactFlash Storage Cards that do not support security mode feature set, this 
command is effectively a NOP command and only implemented for backward compatibility. The 
Sector Count Register shall always be returned with a 00h indicating Wear Level is not needed. If 
the CompactFlash Storage Card supports security mode feature set, this command shall be 
handled as Security Freeze Lock. 
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6.2.1.36 Write Buffer - E8h 


[el [els l*,ts]? [71] 
[ennign@)| CCiaRSSCS*d 


Cyl Low (4) 


seceu@)[—~—SsCSC=“‘“~*S*“‘“SCS 


Figure 90: Write Buffer 


The Write Buffer command enables the host to overwrite contents of the CompactFlash Storage 
Card’s sector buffer with any data pattern desired. This command has the same protocol as the 
Write Sector(s) command and transfers 512 bytes. 


6.2.1.37 Write DMA - CAh 
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Bit -> 7 6 5 4 3 2 1 0 
Command (7) CAh 
C/D/H (6) 1 LBA 1 Drive Head (LBA 27-24) 

Cyl High (5) Cylinder High (LBA 23-16) 

Cyl Low (4) Cylinder Low (LBA 15-8) 
Sec Num (3) Sector Number (LBA 7-0) 

Sec Cnt (2) Sector Count 

Feature (1) Xx 


Figure 91: Write DMA 


This command uses DMA mode to write from 1 to 256 sectors as specified in the Sector Count 
register. A sector count of 0 requests 256 sectors. The transfer begins at the sector specified in 
the Sector Number Register. When this command is issued the CompactFlash Storage Card sets 
BSY, puts all or part of the sector of data in the buffer. The Card is then permitted, although not 
required, to set DRQ, clear BSY. The Card asserts DMAREQ while data is available to be 
transferred. The host then writes the (512 * sector-count) bytes of data to the Card using DMA. 
While DMAREQ is asserted by the Card, the Host asserts -DMACK while it is ready to transfer 
data by DMA and asserts -IOWR once for each 16 bit word to be transferred from the Host. 


Interrupts are not generated on every sector, but upon completion of the transfer of the entire 
number of sectors to be transferred or upon the occurrence of an unrecoverable error. 


At command completion, the Command Block Registers contain the cylinder, head and sector 
number of the last sector read. If an error occurs, the read terminates at the sector where the 
error occurred. The Command Block Registers contain the cylinder, head, and sector number of 
the sector where the error occurred. The amount of data transferred is indeterminate. 
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When a Write DMA command is received by the Card and 8 bit transfer mode has been enabled 
by the Set Features command, the Card shall return the Aborted error. 


6.2.1.38 Write Long Sector - 32h or 33h 


esl De fs l*>lst?t[s 
cone [Di [a [oe | aaa 
Cylinder High (LBA 23-16) 


Cyl Low (4) Cylinder Low (LBA 15-8) 


Sec Num (3) Sector Number (LBA 7-0) 
Sec Cnt (2) 


| Feature} 


Figure 92: Write Long Sector 


This command is similar to the Write Sector(s) command except that it writes 516 bytes instead of 
512 bytes. Only single sector Write Long operations are supported. The transfer consists of 512 
bytes of data transferred in word mode followed by 4 bytes of ECC transferred in byte mode. 
Because of the unique nature of the solid-state CompactFlash Storage Card, the four bytes of 
ECC transferred by the host may be used by the CompactFlash Storage Card. The 
CompactFlash Storage Card may discard these four bytes and write the sector with valid ECC 
data. This command has the same protocol as the Write Sector(s) command. Use of this 
command is not recommended. 
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6.2.1.39 Write Multiple Command - C5h 
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[el [els l*,ls,[? [71] 


Cyl High (5) Cylinder High 


Cyl Low (4) Cylinder Low 


Sec Cnt (2) Sector Count 
| Feature) 


Figure 93: Write Multiple Command 


Note: This specification requires that CompactFlash Cards support a multiple block count of 1 and permits 
larger values to be supported. 


This command is similar to the Write Sectors command. The CompactFlash Storage Card sets 
BSY within 400 nsec of accepting the command. Interrupts are not presented on each sector but 
on the transfer of a block that contains the number of sectors defined by Set Multiple. Command 
execution is identical to the Write Sectors operation except that the number of sectors defined by 
the Set Multiple command is transferred without intervening interrupts. 


DRQ qualification of the transfer is required only at the start of the data block, not on each sector. 
The block count of sectors to be transferred without intervening interrupts is programmed by the 
Set Multiple Mode command, which shall be executed prior to the Write Multiple command. 


When the Write Multiple command is issued, the Sector Count Register contains the number of 
sectors (not the number of blocks or the block count) requested. If the number of requested 
sectors is not evenly divisible by the block count, as many full blocks as possible are transferred, 
followed by a final, partial block transfer. The partial block transfer is for n sectors, where: 


n = (sector count) modulo (block count). 


If the Write Multiple command is attempted before the Set Multiple Mode command has been 
executed or when Write Multiple commands are disabled, the Write Multiple operation shall be 
rejected with an aborted command error. 


Errors encountered during Write Multiple commands are posted after the attempted writes of the 
block or partial block transferred. The Write command ends with the sector in error, even if it is in 
the middle of a block. Subsequent blocks are not transferred in the event of an error. Interrupts 
are generated when DRQ is set at the beginning of each block or partial block. 


The Command Block Registers contain the cylinder, head and sector numbers of the sector 
where the error occurred. The Sector Count Register contains the residual number of sectors that 
need to be transferred for successful completion of the command, e.g., each block has 4 sectors, 
a request for 8 sectors is issued and an error occurs on the third sector. The Sector Count 
Register contains 6 and the address is that of the third sector. 
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6.2.1.40 Write Multiple without Erase - CDh 


[el [es lsl*,ls [7 [71] 
a 
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Figure 94: Write Multiple without Erase 


This command is similar to the Write Multiple command with the exception that an implied erase 
before write operation is not performed. The sectors should be pre-erased with the Erase 
Sector(s) command before this command is issued. 


6.2.1.41 Write Sector(s) - 30h or 3th 


esl? Pe ts «fs t2[* 
(eee ee ee I 


Cyl High (5) Cylinder High (LBA 23-16) 


Cyl Low (4) Cylinder Low (LBA 15-8) 
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Figure 95: Write Sector(s) 


This command writes from 1 to 256 sectors as specified in the Sector Count Register. A sector 
count of zero requests 256 sectors. The transfer begins at the sector specified in the Sector 
Number Register. When this command is accepted, the CompactFlash Storage Card sets BSY, 
then sets DRQ and clears BSY, then waits for the host to fill the sector buffer with the data to be 
written. No interrupt is generated to start the first host transfer operation. No data should be 
transferred by the host until BSY has been cleared by the host. 


For multiple sectors, after the first sector of data is in the buffer, BSY shall be set and DRQ shall 
be cleared. After the next buffer is ready for data, BSY is cleared, DRQ is set and an interrupt is 
generated. When the final sector of data is transferred, BSY is set and DRQ is cleared. It shall 
remain in this state until the command is completed at which time BSY is cleared and an interrupt 
is generated. 


If an error occurs during a write of more than one sector, writing terminates at the sector where 
the error occurs. The Command Block Registers contain the cylinder, head and sector number of 
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the sector where the error occurred. The host may then read the command block to determine 
what error has occurred, and on which sector. 


6.2.1.42 Write Sector(s) without Erase - 38h 


[esl [eps [ets [ets fe 
a 
[em [7 [wk [| oe [need teary 


Cyl High (5) Cylinder High (LBA 23-16) 


Cyl Low (4) Cylinder Low (LBA 15-8) 
Sec Num (3) Sector Number (LBA 7-0) 


Sec Cnt (2) Sector Count 
| Feature) 


Figure 96: Write Sector(s) without Erase 


This command is similar to the Write Sector(s) command with the exception that an implied erase 
before write operation is not performed. This command has the same protocol as the Write 
Sector(s) command. The sectors should be pre-erased with the Erase Sector(s) command before 
this command is issued. If the sector is not pre-erased with the Erase Sector(s) command, a 
normal write sector operation will occur. 


6.2.1.43 Write Verify - 3Ch 
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sel tore ne] ee oe Poe 
0 
Tewme)| 1 [tea [1 ove | vosotanaray | 


Cyl High (5) Cylinder High (LBA 23-16) 


Cyl Low (4) Cylinder Low (LBA 15-8) 


| Sec Num (3), Sector Number (LBA 7-0) 
Sec Cnt (2) Sector Count 
Feature) 


Figure 97: Write Verify 


This command is similar to the Write Sector(s) command, except each sector is verified 
immediately after being written. This command has the same protocol as the Write Sector(s) 
command. 
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6.2.2 Error Posting 
Table 56: Error and Status Register summarizes the valid status and error value for all the 
CF-ATA Command set. 


Table 56: Error and Status Register 


Peak [une [wr [aBnr [amr [oRoy | owe [ osc | conn [ERR 


ferearonernie | [| | [vl] [v[v][vl] |v 
ecutive dag | | |) pv] [vf [v) 
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Flush Cache 


V 
Format Track LJ 
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Idle Immediate Ld 
Initialize Drive Parameters i. al 


Vv 


Key Management V 


Structure Read 


Key Management Vv 


on 
i 
Cote 
es a 
a 


Read Keying Material 

Key Management Change Vv V 

Key Management Value 
Nop 


reader «| iP 
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i 
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a) 
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Le See] 
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P| 8% [une | one [aser [amir [oRoy | owe | ose | corr | ene | 
Samaipowos | | | |v] ~v[v{vl[ |v 
setsiepviods | PP tv |p pt 
seasy | PP 
sandsymmeiae | | | |v] >v[v{v} |v] 
Transtesecor |v | pv i[vlvpviv[v}> |v] 
Werte tv Pw pv |v pv pv pv pd 
Wwiseute | vv 
wicows stv | pv [v[v>vi~v{[v} |v] 
WitstongSear |v | pv |v lv pv pv [vp vd 
Wwiswtine |v | pv |v fv Pv pv [vp [vy 
v 

v 

Witeseaorsywoeae |v | pv |v lvpv[v[vp> |v] 
Wievery |v | pv |v tv pPvp~v iv > |v 
Imvattconmanveoe | [| |v | pv tv lvl |v] 


V = valid on this command ' See Table 46: Diagnostic Codes. 
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6.2.3. Key Management Feature Set 


Support of the optional Key Management feature set is denoted by a non-zero word 162 in the 
IDENTIFY DEVICE response. Commands unique to the Key Management feature set use a 
single command code and are differentiated from one another by the value placed in the Features 
register. These commands are: 


Table 57: Key Management Features register values 


Command 


Po Command 
O0h-7Fh | READ KEY MANAGEMENT STRUCTURE 


READ KEYING MATERIAL 
CHANGE KEY MANAGEMENT VALUE 
82h-FFh 


The READ KEY MANAGEMENT STRUCTURE command returns device status relevant to a Key 
Management scheme. The details of the structure are specific to the given scheme. For the most 
part, this status is dynamic. In contrast, the READ KEYING MATERIAL command returns 
constant information that is set at manufacturing time using vendor-specific methods. This 
information is the keying material necessary for compliant hosts to calculate interoperable keys 
through the card’s media. Its size and format is also specific to the given Key Management 
scheme in use. 
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The READ KEY MANAGEMENT STRUCTURE command has a built-in 39-bit challenge that is 
used by some Key Management schemes to authenticate the card. 


The CHANGE KEY MANAGEMENT VALUE command is used to modify values that are found in 
the READ KEY MANAGEMENT STRUCTURE command’s response. 


CPRM is the only Key Management Scheme that has been adopted. See section 8.4 
Bibliography for references to CPRM documentation. Additional schemes may be considered for 
future adoption as needed. 


Other values of the Feature register and the Head field (bits 3-0) in the C/D/H register are 
reserved for the use of future Key Management schemes. Cards supporting only CPRM should 
abort if the Head field is other than 0. 


6.2.4 Security Mode Feature Set 


The Security Mode feature set allows a host to implement a security password system to prevent 
unauthorized access to the CompactFlash Storage Card. A device that implements the Security 
Mode feature set shall implement the following minimum set of commands: 


= Security Set Password 

= Security Unlock 

= Security Erase Prepare 

= Security Erase Unit 

= Security Freeze Lock 

= Security Disable Password 


Support of the Security Mode feature set is indicated in Identify Device word 128. The Security 
Mode feature set (Command codes F1, F2, F3, F4, F5, and F6) should not be implemented 
unless the device is intended to be used in an embedded, non-removable application. The 
Security Mode feature set was not designed for removable devices and certain problems may be 
encountered when using these commands in a removable application. 


6.2.4.1 Security Mode Default Setting 


The Master password shall be set to a vendor specific value during manufacturing and the Lock 
mode disabled. The system manufacturer/dealer may set a new Master password using the 
Security Set Password command, without enabling or disabling the Lock mode. 


6.2.4.2 Initial Setting of the User Password 


When a User password is set, the device shall automatically enter Lock mode the next time the 
device is powered-on or after a hardware reset. 


6.2.4.3 Security Mode Operation from Power-On or Hardware Reset 


When Lock is enabled, the device rejects media access commands until a Security Unlock 
command is successfully completed. 


6.2.4.4 Frozen Mode 


The Security Freeze Lock command places the device in Frozen mode. This prevents accidental 
or malicious password activation or setting. Table 58: Security Mode Command Actions lists the 
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commands that the device shall be able to execute when in Frozen mode. The device shall exit 
Frozen mode on power off. All devices that support the Security Mode feature set should be 
issued a Security Freeze Lock command during system initialization. 


6.2.4.5 User Password Lost 


If the User password does not match and High level security is set, the device shall not allow the 
user to access data. The device shall be unlocked using the Master password. If the User 
password is lost and Maximum security level is set, data access shall not be allowed. However, 
the Security Erase Unit command shall unlock the device and shall erase all user data if the 
Master password matches. 


6.2.4.6 Attempt Limit for SECURITY UNLOCK Command 
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The device shall have an attempt limit counter. The purpose of this counter is to defeat repeated 
trial attacks. After each failed User or Master password Security Unlock command, the counter is 
decremented. When the counter value reaches zero the Expire bit (bit 4) of word 128 in the 
Identify Device information is set, and the Security Unlock and Security Unit Erase commands are 
command aborted until the device is powered off or hardware reset. The Expire bit shall be 
cleared to zero after power on or hardware reset. The counter shall be set to five after a power on 
or hardware reset. 
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Figure 98: Security Mode Flow 
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Table 58: Security Mode Command Actions 


[Command | Locked | Unlocked | Frozen 
fle —=S*~*~SY Cie cutable | Executable | Executable _| 
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7 CompactFlash Adapters 


7.1 Overview 


CompactFlash and CF+ Type | products can be used with a PCMCIA Type II passive adapters. 
This adapter converts the Type | CompactFlash Storage Card or CF+ Card into a Type I 
PCMCIA PC card. 


CompactFlash and CF+ Type II products can be used with PCMCIA Type II passive adapters. 
This adapter converts the Type Il CompactFlash Storage Card or CF+ Card into a Type Il 
PCMCIA PC card. 


CF adapters shall physically and electrically conform to the PCMCIA PC Card Standard. 


7.2 CompactFlash Adapter Specifications 


7.2.1 
1244 


The following subsections describe the Type | and Type II CompactFlash Adapters. 


Specification applying to all CompactFlash Adapters 


CompactFlash Adapter Overall Mechanical Dimensions 


Refer to Table 59, Figure 100 and Figure 101 for the CompactFlash Adapter physical 
specifications. 


Table 59: CompactFlash Adapter Physical Specifications 


Length: | 85.6 + 0.20 mm (3.370 +.008 in) 
Twine [64.00.10 mm (2.126 2 04 In 


7.2.1.2. CompactFlash Adapter Card Resistance 


When measured between the solder lead pad on the 50 position straddle mount header and the 
solder lead pad on the 68 position receptacle, there should be 150 milliohms maximum bulk 
resistance per circuit. 


Power Supply 
Y Z Y Zp LL LLL GE y | 
Yyy m1 
Yj = ry 
Termination Resistance 


Measurement Points 


Figure 99: Termination Resistance Measurement Points 
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7.2.1.3 Ground Clip & Resistance 


The CF to PC Card Adapter should have two ground clips, one on each side to support I/O cards 
that utilize ground clips. If the ground clips are present on the Adapter, the remainder of this 
section shall apply. 


The size and dimension of the ground clips are not defined, only that they shall meet PCMCIA 
specification in terms of resistance. The contact resistance as specified in the PCMCIA Card 
Physical section 6.1 shall be adopted in its entirety. The ground clips on the CF Type Il and CF+ 
are specified in the card physical. 


The contact resistance path is measured from the center of the PC Card nearest 68 pin connector 
(Test Point A) to the center of the CompactFlash card at the rear (Test Point B). 


Table 60: Termination Resistance Procedure 


Termination Resistance Initial: Subject samples to 50 mV 


Signal, 260 millionms maximum. maximum open circuit at 100 mA 
Ground, 100 milliohms maximum. maximum. 
AR 20 millionms maximum. 


7.2.2 Type | CompactFlash Adapter Diagram 
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Type | CompactFlash Adapters are used to adapt Type | CompactFlash and CF+ cards for use in 
Type II (5 mm thick) PCMCIA card slots. The mechanical drawing for Type | adapters appears in 
Figure 100: Type | CompactFlash Adapter. 
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5.0mm (0.196 in.) 3.3mm (0.130 in.) 


lg. 54.0mm 
(2.126 in.) 


36.40mm 
(1.483 in.) 


39.03mm 
_ (1.536 in.) 
12.00mm 


(.472 in.) 2.0mm 
(.078 in.) 


3.5mm 


43.03mm 0.138 in. 
: (1.694 in.) : m) 


eco000000O COCO OOO0000000000 
eoo0000000000000000000000 


Figure 100: Type | CompactFlash Adapter 
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7.2.3. Type Il CompactFlash Adapter Specifications 
Type Il CompactFlash Adapters are used to adapt Type II CompactFlash and CF+ cards for use 
in Type Il (56 mm thick) PCMCIA card slots. The diagram for these adapters is show below and 


the other specifications are presented in the following subsections. 


3.370 4,008 
(85.60 4,201 0 A=sER 
(1.0 4.05) (1,0 +/- .05] 
2,923 [74.25] MAX 
2.B00 (71.12) NOX ———s HIGH VOLTAGE KEY 
2,726 (69.25) MIN 
4 SCALE 3/1 
1.930 (49,25) MAX rae 
=— 1.931 (49.05) NM} oy 
1.913 (48.60) MIN (3.00) 
PIN 26 
PIN | PIN 35 
PIN 1 
035 
.89] 
1.695 
(43.051 2.126 +.004 
FRONT VIEW 
(54.00 £.10] 68 PIN CONNECTOR 
PIN 25 
PINS PIN 68 
PIN 50 it 
aoe 
Teel: anu aes 
O65 +,.002 
(1.65 4,05] 035 [90] MAX ’ ‘ BB. FIN CONNECTIR 
\ FOR REFERENCE ONLY 
000 £,00] MIN Jax H ‘ 
U 
TOP VIEW-COVER PLATE y 
ita 
039 +.002 
(1.0 4.05) 


BACK VIEN 
063 £.002 i 
(1.60 +.05) 


SIDE VIEW 
VIIAQ REVISION 8 ---ADDED CIRCLED DIMENSION se ae 
5/124/99 REVISION C ---DADDITIONAL TOLERANCES 


Figure 101: Type Il CompactFlash Adapter 


7.2.3.1. Shutter Mechanism 
The Shutter Mechanism is defined as a protective device or shield for the 50 pin host pins. The 
shutter, in its fully extended position, shall not exceed .035 in. [.90 mm] max or 0.00 in. [0.00 MM] 


min from the longest pin. 


7.2.3.2 Position of CompactFlash Type II Card 
The CF Type II standard length Card, when fully inserted to the PC Card adapter, shall be flush 


with the rear of the Adapter. The CF Type II standard length Card shall not protrude past the 
PCMCIA PC Card Type II specification, nor shall it be recessed when inserted into the PC Card 
Adapter. 


7.2.3.3 Mating and Unmating Force 
See Table 3: Connector Interface Requirement- Total Mating Force and Total Unmating Force. 
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7.2.3.4 Key / Rail Length 


The rail length is specified as 69.25 mm Minimum to 74.25 mm Maximum. The purpose is to 
improve stability of the CF Type II Card to the PC Card Type II Adapter. 


7.2.3.5 Force to Overcome Shutter Locking Mechanism 


The shutter mechanism is designed with a lock to prevent movement of the shutter when the CF 
Type II Card is not engaged. This lock is to prevent pin damage to the 50 host pins. The force to 
overcome this mechanism is specified as 29.4N Minimum 


7.2.3.6 Shutter Force 


The amount of force necessary to move the shutter mechanism, once the shutter lock mechanism 
has been disengaged is not to exceed the minimum Unmating force of the 50 pin host connector: 
4.9N Maximum. 


7.3 Electrical Differences Between the CompactFlash Storage/CF+ Card and the 
CompactFlash Adapter 


The CompactFlash Storage Card and the CompactFlash CF+ Card are electrically compatible 
with the CompactFlash Adapter. When a CompactFlash or CF+ card is installed in a 
CompactFlash adapter, the combination conforms to the PCMCIA PC Card Standard. 
CompactFlash products use a 50 pin connector and CompactFlash Adapters use a 68 pin 
connector. Both connectors use less than 50 signals. Table 50 shows the pinout differences 
between the CompactFlash Storage/CF+ Card and the CompactFlash Adapter. 
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Table 61: Pinout Differences Between CF Storage Card and CF Adapter 


68 Pin 50 Pin 
Pin # Pin# 


[veer [Pinte |_| 
[ate [Pnte |_| 
[ais [Pina |_| 
all 
Fin | 


A05 


Pin 25 


00 


Pin 16 


CF Storage/ 
CF+ Card 
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GND 


-CE1 
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(_ATA SEL) 


AO9 
A08 


-WE 


READY / 
-IREQ 
(INTRQ) 


Vcc 


A07 
A06 
A05 


A04 


A03 


A02 


A01 


A0O 


CF Adapter 
68 Pin 


GND 
-CD1 
D11 
D12 
D13 
D14 
D15 


-CE2 


-VS1 


-IORD 
-IOWR 
A17 
A18 
A19 
A20 
A21 


Vcc 
VPP2 
A22 
A23 
A24 
A25 
-VS2 
RESET 


-WAIT 


-INPACK 


-REG 


BVD2 / 
-SPKR 


BVD1 / 
-STSCHG 
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CF+ Card 
50 Pin 


68 Pin 50 Pin 
Pin # i 


3 
| Pin36 | Pin 26 
| Pin37 | Pin 27 
| Pin38 | Pin 28 
| Pin39 | Pin 29 
| Pin 40 | Pin 30 


| Pin 44 | Pin 34 
| Pin 4s | Pin 35 


Pin 32 


u a 
5 5 
= * 


Pin 38 
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Pin 39 
Pin 40 
Pin 41 


RESET 
(-RESET) 
-WAIT 
(IOREADY) 
-INPACK 
(-DMARQ?) 
-REG 
(DMACK? ) 


Pin 42 


Pin 43 


Pin 44 


Pin 45 


Pin 46 


COMPACTFLASH ADAPTER 


CF Adapter | 68 Pin 50 Pin | CF Storage/ | CF Adapter | 68 Pin 50 Pin | CF Storage/ 
68 Pin Pin # Pin # CF+ Card 68 Pin Pin # Pin # CF+ Card 
50 Pin 50 Pin 


WP / Pin33 | Pin24 WP / Pin67 | Pin 25 -CD2 
-1OIS16 -1OIS16 
(-lIOCS16) 


GND Pin 50 Pin 68 GND 


Notes: A signal name appearing alone is a PC Card memory mode, PC Card I/O and True IDE 
signal name 
A signal appearing alone before a “(” is both a PC Card memory mode and PC Card I/O mode 
signal name. 
A signal appearing before “/” is a PC Card memory mode signal name. 
A signal appearing after “/” is a PC Card I/O mode signal name. 
A signal appearing in “( by is a True IDE mode signal name. 
A signal appearing in “( -)’ is a True IDE mode DMA-only signal name. 


7.4 CF Adapter Design Considerations 


It is recommended that the 68-pin PCMCIA to 50-pin CF adapter board be constructed with a 
multi-layer board having a ground plane along with ground traces between signals on the top and 
bottom of this board for electrical cross-talk isolation. 
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8 Appendix 


8.1 Differences between CF/CF+ and PCMCIA, and between CF-ATA and PC 
Card-ATA/True IDE 


This section details differences between CF/CF+ vs. PC Card, CF-ATA vs. PC Card ATA and 
between CF-ATA vs. True IDE. 


8.1.1 CF/CF+ Electrical Differences 


8.1.1.1 TTL Compatibility 
CF is not TTL compatible, it is a purely CMOS interface. Refer to Section 4.3 of this specification. 


8.1.1.2 Pull-Up Resistor Input Leakage Current 


The minimum pull-up resistor input leakage is 50k ohms rather than the 10k ohms stated in the 
PCMCIA specification. 


8.1.1.3 Wait Width Time 


The Wait Width Time for CompactFlash Storage Cards is 350 ns and is 3s for CF+ Cards, rather 
than 12 us as stated in the PCMCIA specification. 


8.1.2 ATA Functional Differences 


8.1.2.1 Additional Set Features Codes in CF-ATA 


The following Set Features codes are not PC Card ATA or True IDE, but provide additional 
functionality in CF-ATA. 


= 69h, Accepted for backward compatibility 
= 96h, Accepted for backward compatibility 
= 97h, Accepted for backward compatibility 
» QAh, Set the host current source capability 


8.1.2.2 Additional Commands in CF-ATA 


The following commands are not standard PC Card ATA commands, but provide additional 
functionality in CF-ATA. 


The command codes for the commands below are defined as vendor unique in PC Card 
ATA/True IDE. 


= COh, Erase Sectors 
= 87h, Translate Sector 
= F5h, Wear Level 


The command codes for the commands below are defined as reserved in PC Card ATA/True 
IDE: 


= 03h, Request Sense 
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= 38h, Write Without Erase 
«= CDh, Write Multiple Without Erase 


8.1.2.3 Idle Timer 


The Idle timer uses an incremental value of 5 ms, rather than the 5 sec minimum increment value 
specified in PC Card ATA/True IDE. 


8.1.2.4 Recovery from Sleep Mode 


For CF Storage devices, recovery from sleep mode is accomplished by simply issuing another 
command to the device. A hardware or software reset is not required. 


8.2 Differences Between CompactFlash Storage Cards and CF+ Cards 


CompactFlash and other Data Storage Cards shall have their Configuration Registers at offset 
200h. On non-data storage CF+ Cards the location of the Configuration Registers is determined 
by parsing the CIS (Tuples). 


CompactFlash and other Data Storage Cards need to support a Maximum Wait Width pulse of 
350 ns, whereas non-data storage CF+ Cards only need to support a 3 us pulse. 


CompactFlash and other Data Storage Cards shall support all three access modes, memory, I/O 
and True IDE, whereas non-data storage CF+ Cards only need to support memory and I/O 
access (True IDE mode is optional). 


Any card that uses Power Level 1, either via the configuration registers or ATA commands, is 
considered a CF+ card. 


8.3 Term Definitions 


Identify Device — The name used for ATA Command Code ECh in this and future revisions of 
this specification. Was formerly referred to as Identify Drive. 


Identify Drive — The name used for ATA Command Code ECh, the Identify Device command, in 
previous revisions of this specification. Also referred to as ID Drive. 


mandatory — A keyword indicating items to be implemented as defined by this standard. 
may — A keyword that indicates flexibility of choice with no implied preference. 


obsolete — A keyword used to describe bits, bytes, fields, and code values that no longer have 
consistent meaning or functionality from one implementation to another. However, some degree 
of functionality may be required for items designated as “obsolete” to provide for backward 
compatibility. An obsolete bit, byte, field, or command shall never be reclaimed for any other use 
in any future standard. Obsolete commands should not be used by the host. Commands defined 
as obsolete in previous standards may be command aborted by devices conforming to this 
standard. However, if a device does not command abort an obsolete command, the minimum that 
is required by the device in response to the command is command completion. 


optional - A keyword that describes features that are not required by this standard. However, if 


any optional feature defined by the standard is implemented, the feature shall be implemented in 
the way defined by the standard. 
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reserved - A keyword indicating reserved bits, bytes, words, fields, and code values that are set 
aside for future standardization. Their use and interpretation may be specified by future 
extensions to this or other standards. A reserved bit, byte, word, or field shall be set to zero, or in 
accordance with a future extension to this standard. The recipient shall not check reserved bits, 
bytes, words, or fields. Receipt of reserved code values in defined fields shall be treated as a 
command parameter error and reported by returning command aborted. 


shall - A keyword indicating a mandatory requirement. Designers are required to implement all 
such mandatory requirements to ensure interoperability with other standard conformant products. 


should - A keyword indicating flexibility of choice with a strongly preferred alternative. Equivalent 
to the phrase “it is recommended”. 
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9 Revision History 


z 
measurement instructions; added datum A at card socket to drawings. 
Added CF+ Specifications. Added updated ATA Command set. 


Changed name to CF+ & CompactFlash, incorporated comments regarding Power and 
True IDE mode. 


Editorial changes. Added CompactFlash vs. CF+ Appendix. Added power measurement 
schematic. 


Added note regarding CF Type II to PCMCIA adapter. Added CF Type II host connector. 


Updated Figure 16, “Surface Mount Right Angle CF/CF+ Type | Card Slot Header” 
drawing. 


| ta 
2 
Added support for many ATA-4 features including updated ID Drive information, additional 
PIO modes, additional Set Features options and additional commands. 
Corrected inconsistencies and errors in signal naming, signal descriptions, host signal 
termination and card signal termination. 
Corrected inconsistencies and errors in numbering and cross-references. 
Added adapter for CF Type II to PCMCIA Type II. 
Added Key Management Feature Set commands and descriptions. 
Added longer and extended mechanical form-factors. 
Changed format of CF Adapter table. 
Corrected formatting, spelling and grammatical inconsistencies. 
Corrected inconsistencies in Figures 3, 4, 17 and 30. 


Added True IDE Mode Multiword DMA. 

Obsolete Twin Card feature 

Change Driver Specification to 4 ma. 

Made Linguistic Clarifications. 

Added Alerts for ID Drive Word 0 and Set Features 09h, 89h 
Added Minimum Inverse Insertion Force specified as 43.2 N. 
Clarified Reset Pull-up Handling 

Added Acknowledgement of Contributors 

Added Ultra DMA Diagrams and Text using CFA terminology 
Added Advanced Timing Modes Diagrams and Text using CFA terminology. 
Fixed borders and placement of diagrams 

Propagated Identify Device Language from 2.1 Release 
Changed ID Drive Word 0 to allow non 848Ah values. 
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REVISION HISTORY 


Changed captions, footnotes, cross-references to CFA standard. 


Expanded Signal Description Table descriptions of UDMA signals. 
Fixed document automation and cross reference problems. 
Added CRC logic description from ATA-4 specification for Ultra-DMA 


Removed ATA-4 cross-references from preliminary diagrams and placed referenced 
language from section 9 of ATA spec in paragraphs before diagrams. 


Adjusted tables and figures to fit in standard margins. 
Added section 5.2.1 on representing Extended Speed Memory Modes in CIS. 
Updated Section 4.7 to incorporate Ultra DMA transfers. 
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